1 #@ MODIF calc_table_ops Macro DATE 16/05/2007 AUTEUR COURTOIS M.COURTOIS
2 # -*- coding: iso-8859-1 -*-
3 # CONFIGURATION MANAGEMENT OF EDF VERSION
4 # ======================================================================
5 # COPYRIGHT (C) 1991 - 2005 EDF R&D WWW.CODE-ASTER.ORG
6 # THIS PROGRAM IS FREE SOFTWARE; YOU CAN REDISTRIBUTE IT AND/OR MODIFY
7 # IT UNDER THE TERMS OF THE GNU GENERAL PUBLIC LICENSE AS PUBLISHED BY
8 # THE FREE SOFTWARE FOUNDATION; EITHER VERSION 2 OF THE LICENSE, OR
9 # (AT YOUR OPTION) ANY LATER VERSION.
11 # THIS PROGRAM IS DISTRIBUTED IN THE HOPE THAT IT WILL BE USEFUL, BUT
12 # WITHOUT ANY WARRANTY; WITHOUT EVEN THE IMPLIED WARRANTY OF
13 # MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. SEE THE GNU
14 # GENERAL PUBLIC LICENSE FOR MORE DETAILS.
16 # YOU SHOULD HAVE RECEIVED A COPY OF THE GNU GENERAL PUBLIC LICENSE
17 # ALONG WITH THIS PROGRAM; IF NOT, WRITE TO EDF R&D CODE_ASTER,
18 # 1 AVENUE DU GENERAL DE GAULLE, 92141 CLAMART CEDEX, FRANCE.
19 # ======================================================================
21 # RESPONSABLE MCOURTOI M.COURTOIS
23 EnumTypes = (ListType, TupleType)
25 def calc_table_ops(self, TABLE, ACTION, INFO, **args):
27 Macro CALC_TABLE permettant de faire des opérations sur une table
33 from Cata.cata import table_sdaster, table_fonction, table_jeveux
34 from Utilitai.Utmess import UTMESS
35 from Utilitai import transpose
36 from Utilitai.Table import Table, merge
39 # La macro compte pour 1 dans la numerotation des commandes
42 # Le concept sortant (de type table_sdaster ou dérivé) est tabout
43 self.DeclareOut('tabout', self.sd)
44 if self.sd.__class__ == table_fonction:
45 typ_tabout = 'TABLE_FONCTION'
49 # On importe les definitions des commandes a utiliser dans la macro
50 # Le nom de la variable doit etre obligatoirement le nom de la commande
51 CREA_TABLE = self.get_cmd('CREA_TABLE')
52 DETRUIRE = self.get_cmd('DETRUIRE')
54 # 0. faut-il utiliser une table dérivée
55 form_sens='\n... SENSIBILITE AU PARAMETRE %s (SD COMP %s)'
56 if args['SENSIBILITE']:
57 ncomp = self.jdc.memo_sensi.get_nocomp(TABLE.nom, args['SENSIBILITE'].nom)
58 sdtab = table_jeveux(ncomp)
59 tab = sdtab.EXTR_TABLE()
61 tab = TABLE.EXTR_TABLE()
63 #----------------------------------------------
64 # Boucle sur les actions à effectuer
66 occ = fOP.cree_dict_valeurs(fOP.mc_liste)
67 for mc, val in occ.items():
71 #----------------------------------------------
72 # 1. Traitement du FILTRE
73 # format pour l'impression des filtres
74 form_filtre = '\nFILTRE -> NOM_PARA: %-16s CRIT_COMP: %-4s VALE: %s'
75 if occ['OPERATION'] == 'FILTRE':
76 col = getattr(tab, occ['NOM_PARA'])
77 # peu importe le type, c'est la meme méthode d'appel
78 opts = [occ[k] for k in ('VALE','VALE_I','VALE_C','VALE_K') if occ.has_key(k)]
80 for k in ('CRITERE','PRECISION'):
83 tab = tab & ( getattr(col, occ['CRIT_COMP'])(*opts,**kargs) )
84 # trace l'operation dans le titre
85 #if FORMAT in ('TABLEAU','ASTER'):
86 tab.titr += form_filtre % (occ['NOM_PARA'], occ['CRIT_COMP'], \
87 ' '.join([str(v) for v in opts]))
89 #----------------------------------------------
90 # 2. Traitement de EXTR
91 if occ['OPERATION'] == 'EXTR':
92 lpar = occ['NOM_PARA']
93 if not type(lpar) in EnumTypes:
97 UTMESS('F', macro, 'Paramètre %s inexistant dans la table %s' % (p, TABLE.nom))
98 tab = tab[occ['NOM_PARA']]
100 #----------------------------------------------
101 # 3. Traitement de RENOMME
102 if occ['OPERATION'] == 'RENOMME':
104 tab.Renomme(*occ['NOM_PARA'])
105 except KeyError, msg:
106 UTMESS('F', macro, msg)
108 #----------------------------------------------
109 # 4. Traitement du TRI
110 if occ['OPERATION'] == 'TRI':
111 tab.sort(CLES=occ['NOM_PARA'], ORDRE=occ['ORDRE'])
113 #----------------------------------------------
114 # 5. Traitement de COMB
115 if occ['OPERATION'] == 'COMB':
116 tab2 = occ['TABLE'].EXTR_TABLE()
118 if occ.get('NOM_PARA') != None:
119 lpar = occ['NOM_PARA']
120 if not type(lpar) in EnumTypes:
123 if not p in tab.para:
124 UTMESS('F', macro, 'Paramètre %s inexistant dans la table %s' % (p, TABLE.nom))
125 if not p in tab2.para:
126 UTMESS('F', macro, 'Paramètre %s inexistant dans la table %s' % (p, occ['TABLE'].nom))
130 #----------------------------------------------
131 # 6. Traitement de OPER
132 if occ['OPERATION'] == 'OPER':
133 # ajout de la colonne dans la table
134 tab.fromfunction(occ['NOM_PARA'], occ['FORMULE'])
136 vectval = getattr(tab, occ['NOM_PARA']).values()
137 aster.affiche('MESSAGE', 'Ajout de la colonne %s : %s' % (occ['NOM_PARA']+repr(vectval))+'\n')
139 #----------------------------------------------
140 # 99. Création de la table_sdaster résultat
141 # cas réentrant : il faut détruire l'ancienne table_sdaster
142 if self.sd.nom == TABLE.nom:
143 DETRUIRE(CONCEPT=_F(NOM=TABLE.nom,), INFO=1)
145 dprod = tab.dict_CREA_TABLE()
148 echo_mess.append( '@-'*30+'\n' )
149 echo_mess.append( tab )
150 from pprint import pformat
151 echo_mess.append( pformat(dprod) )
152 echo_mess.append( '@-'*30+'\n' )
153 texte_final = ' '.join(echo_mess)
154 aster.affiche('MESSAGE', texte_final)
156 # surcharge par le titre fourni
159 if not type(tit) in EnumTypes:
161 dprod['TITRE'] = tuple(['%-80s' % lig for lig in tit])
162 # type de la table de sortie à passer à CREA_TABLE
163 tabout = CREA_TABLE(TYPE_TABLE=typ_tabout,