File: burettelistwidget.py

package info (click to toggle)
pyacidobasic 2.5-1
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 3,180 kB
  • ctags: 131
  • sloc: python: 1,183; xml: 71; makefile: 32; sh: 6
file content (108 lines) | stat: -rw-r--r-- 3,428 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
#-*- coding: utf-8 -*-


licence="""
    file burettelistwidget.py: part of the package pyacidobasic version %s:

    Copyright (C) 2010 Georges Khaznadar <georgesk@ofset.org>

    This program is free software: you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation, either version 3 of the License, or
    (at your option) any later version.

    This program is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.

    You should have received a copy of the GNU General Public License
    along with this program.  If not, see <http://www.gnu.org/licenses/>.
"""

from PyQt4.QtCore import *
from PyQt4.QtGui import *
from becherlistwidget import BecherListWidget

class BuretteListWidget(BecherListWidget):

    def renseigneParametres(self,ab):
        """
        Renseigne les paramètres manquants pour l'acide/base ajouté
        """
        ab.c=QInputDialog.getDouble(None,u"burette", QString("Entrez la concentration (%s)" %ab.nom),0.1,0.0,50,3)[0]

    def vide(self):
        """
        Supprime les contenus de la liste
        et réactive la réception des drops
        """
        BecherListWidget.vide(self)
        self.setAcceptDrops(True)
        
    def dropEvent(self, event):
        BecherListWidget.dropEvent(self, event)
        # interdit les drops dès qu'on a un produit là.
        if self.count()>0:
            self.setAcceptDrops(False)

    def nouveauTexte(self,ab):
        """
        Le nouveau texte à afficher concernent l'acide/base
        @param ab : l'acide/base à considérer
        """
        return "%s %s mol/L" %(ab.nom,ab.c)

    def chargeNette(self,pH,v):
       """
       Renvoie la charge nette de ce qui a coulé de la burette, en
       fonction du pH, compte non tenu des ions H+. UNité : le Faraday.
       @param pH le pH
       @param v le volume versé.
       """
       if len (self.contenu) >0:
           ab=self.contenu[0]
           ab.v=v
           return ab.chargeNette(pH)
       else:
           return 0.0

    def dump(self):
        """
        renvoie un objet à sauvegarder en cas d'écriture dans un fichier
        @return une instance acide-base ou None
        """
        if len (self.contenu) >0:
            return self.contenu[0]
        else:
            return None

    def load(self, obj):
        """
        Récupère une donnée venant d'un fichier
        @param obj un acide-base ou None
        """
        self.clear()
        self.contenu=[]
        if obj != None:
            self.contenu.append(obj)
            self.addItem(self.nouveauTexte(obj))
        
    
    def chargeEau(self,pH,v):
       """
       renvoie la charge électrique porté par les protons et les ions
       hydroxyde, en fonction du pH et du volume v versé de la burette
       @param pH le pH
       @param v le volume versé.
       """
       return (10**(-pH)-10**(pH-14))*v*1e-3
    
    def charge(self, pH, v):
        """
        Renvoie la charge électrique totale, en fonction du pH
        et du volume v versé de la burette
        @param pH le pH
        @param v le volume versé.
        """
        return self.chargeNette(pH,v) + self.chargeEau(pH,v)