X-Git-Url: http://iramuteq.org/git?p=iramuteq;a=blobdiff_plain;f=listlex.py;h=dea3c98d5bbe07974c988c6a2b136e986d8dc8bb;hp=46d3b54700ef7eccfd4147b3775ffe8a19ab1caf;hb=3647a911117ea08f4f969720a16c58bcc7d4e809;hpb=8fa853a25a9d62b1446e1bc543e5a3a4d0e03dcf diff --git a/listlex.py b/listlex.py index 46d3b54..dea3c98 100644 --- a/listlex.py +++ b/listlex.py @@ -18,119 +18,153 @@ import wx import wx.lib.mixins.listctrl as listmix import cStringIO import tempfile -from functions import exec_rcode, MessageImage +from functions import exec_rcode, doconcorde from chemins import ffr from PrintRScript import barplot -from dialog import SearchDial +from dialog import SearchDial, message, BarGraphDialog, MessageImage, BarFrame +from operator import itemgetter #--------------------------------------------------------------------------- -class List(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin): - def __init__(self, parent, ID, pos=wx.DefaultPosition, - size=wx.DefaultSize, style=0): - wx.ListCtrl.__init__(self, parent, ID, pos, size, style) - listmix.ListCtrlAutoWidthMixin.__init__(self) - -class ListForSpec(wx.Panel, listmix.ColumnSorterMixin): - def __init__(self, parent,gparent, dlist,first): +class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSorterMixin): + def __init__(self, parent,gparent, dlist = {}, first = [], usefirst = False, menu = True): + #def __init__(self, parent) : + wx.ListCtrl.__init__( self, parent, -1, style=wx.LC_REPORT|wx.LC_VIRTUAL|wx.LC_HRULES|wx.LC_VRULES) self.parent=parent self.gparent=gparent self.dlist=dlist self.first = first - wx.Panel.__init__(self, parent, -1, style=wx.WANTS_CHARS) - + self.tgen = False + if 'etoiles' in dir(self.gparent) and not usefirst : + self.etoiles = self.gparent.etoiles + else : + self.etoiles = [] + for val in self.first : + if val.startswith(u'X.') : + val = val.replace(u'X.', u'*') + self.etoiles.append(val) + self.menu = menu + + #def start(self) : search_id = wx.NewId() self.parent.Bind(wx.EVT_MENU, self.onsearch, id = search_id) self.accel_tbl = wx.AcceleratorTable([(wx.ACCEL_CTRL, ord('F'), search_id)]) self.SetAcceleratorTable(self.accel_tbl) self.il = wx.ImageList(16, 16) - - self.sm_up = self.il.Add(getSmallUpArrowBitmap()) - self.sm_dn = self.il.Add(getSmallDnArrowBitmap()) + a={"sm_up":"GO_UP","sm_dn":"GO_DOWN","w_idx":"WARNING","e_idx":"ERROR","i_idx":"QUESTION"} + for k,v in a.items(): + s="self.%s= self.il.Add(wx.ArtProvider_GetBitmap(wx.ART_%s,wx.ART_TOOLBAR,(16,16)))" % (k,v) + exec(s) + self.SetImageList(self.il, wx.IMAGE_LIST_SMALL) tID = wx.NewId() - self.list = List(self, tID, - style=wx.LC_REPORT - | wx.BORDER_NONE - | wx.LC_EDIT_LABELS - | wx.LC_SORT_ASCENDING - ) + self.attr1 = wx.ListItemAttr() + self.attr1.SetBackgroundColour((230, 230, 230)) + self.attr2 = wx.ListItemAttr() + self.attr2.SetBackgroundColour("light blue") + self.attrselected = wx.ListItemAttr() + self.attrselected.SetBackgroundColour("red") + self.selected = {} - self.list.SetImageList(self.il, wx.IMAGE_LIST_SMALL) - - self.dlist = dlist - self.PopulateList(dlist,first) - self.Bind(wx.EVT_SIZE, self.OnSize) - - self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self.list) - self.Bind(wx.EVT_LIST_COL_CLICK, self.OnColClick) - - # for wxMSW - self.list.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) + i=0 + for name in [u'formes'] + self.etoiles : + self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) + i+=1 + + self.SetColumnWidth(0, 180) - # for wxGTK - self.list.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) + for i in range(0,len(self.first)): + self.SetColumnWidth(i + 1, self.checkcolumnwidth(len(self.first[i]) * 10)) + self.itemDataMap = self.dlist + self.itemIndexMap = self.dlist.keys() + self.SetItemCount(len(self.dlist)) - self.itemDataMap = dlist - listmix.ColumnSorterMixin.__init__(self, len(first)) - self.SortListItems(1, False) - self.do_greyline() + #listmix.ListCtrlAutoWidthMixin.__init__(self) + listmix.ColumnSorterMixin.__init__(self, len(self.first) + 1) + self.SortListItems(1, 0) #----------------------------------------------------------------------------------------- + self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) + + self.Bind(wx.EVT_LIST_ITEM_ACTIVATED , self.OnPopupTwo, self) + # for wxMSW + self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) - def PopulateList(self, dlist,first): - i=0 - for name in first : - self.list.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) - i+=1 - ct=0 - for key,data in dlist.iteritems() : - ct+=1 - index = self.list.InsertStringItem(sys.maxint, str(data[0])) - i=1 - for val in data[1:]: - self.list.SetStringItem(index, i, str(data[i])) - i+=1 + # for wxGTK + self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) - self.list.SetItemData(index, key) - - self.list.SetColumnWidth(0, wx.LIST_AUTOSIZE) - for i in range(1,len(first)-1): - self.list.SetColumnWidth(i, 130) +#----------------------------------------------------------------------------------------- + def RefreshData(self, data): + self.itemDataMap = data + self.itemIndexMap = data.keys() + self.SetItemCount(len(data)) + self.Refresh() - def do_greyline(self): - for row in xrange(self.list.GetItemCount()): - if row % 2 : - self.list.SetItemBackgroundColour(row,(230,230,230)) + def checkcolumnwidth(self, width) : + if width < 80 : + return 80 + else : + return width + + def OnGetItemText(self, item, col): + index=self.itemIndexMap[item] + s = self.itemDataMap[index][col] + return s + + def OnGetItemAttr(self, item): + if self.getColumnText(item, 0) not in self.selected : + if item % 2 : + return self.attr1 else : - self.list.SetItemBackgroundColour(row,wx.WHITE) - + return self.attr2 + else : + return self.attrselected + + def GetItemByWord(self, word): + return [ val for val in self.dlist if self.dlist[val][0] == word ][0] # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py def GetListCtrl(self): - return self.list + return self # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py def GetSortImages(self): return (self.sm_dn, self.sm_up) - - + def OnRightDown(self, event): x = event.GetX() y = event.GetY() - item, flags = self.list.HitTest((x, y)) + item, flags = self.HitTest((x, y)) if flags & wx.LIST_HITTEST_ONITEM: - self.list.Select(item) + self.Select(item) event.Skip() + + def GetString(self, evt): + return self.getselectedwords()[0] + + def GetSelections(self): + return self.getselectedwords() def getColumnText(self, index, col): - item = self.list.GetItem(index, col) + item = self.GetItem(index, col) return item.GetText() + def GetItemData(self, item) : + index=self.itemIndexMap[item] + s = self.itemDataMap[index] + return s + + def SortItems(self,sorter=cmp): + items = list(self.itemDataMap.keys()) + items.sort(sorter) + self.itemIndexMap = items + # redraw the list + self.Refresh() + def OnItemSelected(self, event): self.currentItem = event.m_itemIndex event.Skip() @@ -138,138 +172,155 @@ class ListForSpec(wx.Panel, listmix.ColumnSorterMixin): def onsearch(self, evt) : self.dial = SearchDial(self, self, 0, True) self.dial.CenterOnParent() - self.dial.ShowModal() - self.dial.Destroy() + self.dial.Show() + #self.dial.Destroy() def OnRightClick(self, event): - - # only do this part the first time so the events are only bound once - if not hasattr(self, "popupID1"): - self.popupID1 = wx.NewId() - self.popupID2 = wx.NewId() - self.popupID3 = wx.NewId() - self.popup_Tgen_glob = wx.NewId() - - self.Bind(wx.EVT_MENU, self.OnPopupOne, id=self.popupID1) - self.Bind(wx.EVT_MENU, self.OnPopupTwo, id=self.popupID2) - self.Bind(wx.EVT_MENU, self.OnPopupThree, id=self.popupID3) - self.Bind(wx.EVT_MENU, self.OnTgen_glob, id=self.popup_Tgen_glob) - # make a menu - menu = wx.Menu() - # add some items - menu.Append(self.popupID1, u"Formes associées") - menu.Append(self.popupID2, u"Concordancier") - menu.Append(self.popupID3, "Graphique") - #menu.Append(self.popup_Tgen_glob, "Tgen global") - - self.PopupMenu(menu) - menu.Destroy() - + if self.menu : + # only do this part the first time so the events are only bound once + if not hasattr(self, "popupID1"): + self.popupID1 = wx.NewId() + self.popupID2 = wx.NewId() + self.popupID3 = wx.NewId() + self.popup_Tgen_glob = wx.NewId() + self.onmaketgen = wx.NewId() + self.ID_stcaract = wx.NewId() + + self.Bind(wx.EVT_MENU, self.OnPopupOne, id=self.popupID1) + self.Bind(wx.EVT_MENU, self.OnPopupTwo, id=self.popupID2) + self.Bind(wx.EVT_MENU, self.OnPopupThree, id=self.popupID3) + self.Bind(wx.EVT_MENU, self.OnTgen_glob, id=self.popup_Tgen_glob) + self.Bind(wx.EVT_MENU, self.OnMakeTgen, id=self.onmaketgen) + #self.Bind(wx.EVT_MENU, self.onstcaract, id = self.ID_stcaract) + # make a menu + menu = wx.Menu() + # add some items + menu.Append(self.popupID1, u"Formes associées") + menu.Append(self.popupID2, u"Concordancier") + menu.Append(self.popupID3, u"Graphique") + menu_stcaract = wx.Menu() + self.menuid = {} + for i, et in enumerate(self.etoiles) : + nid = wx.NewId() + self.menuid[nid] = i + menu_stcaract.Append(nid, et) + self.Bind(wx.EVT_MENU, self.onstcaract, id = nid) + menu.AppendMenu(-1, u"Segments de texte caractéristiques", menu_stcaract) + #menu.Append(self.popup_Tgen_glob, "Tgen global") + if not self.tgen : + menu.Append(self.onmaketgen, "Make Tgen") + self.PopupMenu(menu) + menu.Destroy() + + def getselectedwords(self) : + words = [self.getColumnText(self.GetFirstSelected(), 0)] + last = self.GetFirstSelected() + while self.GetNextSelected(last) != -1: + last = self.GetNextSelected(last) + words.append(self.getColumnText(last, 0)) + return words def OnPopupOne(self, event): activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) corpus = page.corpus - word = self.getColumnText(self.list.GetFirstSelected(), 0) + word = self.getselectedwords()[0] lems = corpus.getlems() rep = [] for forme in lems[word].formes : - rep.append([corpus.getforme(forme).forme, corpus.getforme(forme).freq]) - win = message(self, -1, u"Formes associées", size=(300, 200), style=wx.DEFAULT_FRAME_STYLE) - win.html = '\n' + '
'.join([' : '.join([str(val) for val in forme]) for forme in rep]) + '\n' - win.HtmlPage.SetPage(win.html) + rep.append([corpus.getforme(forme).forme, corpus.getforme(forme).freq]) + rep.sort(key = itemgetter(1), reverse = True) + items = dict([[i, '' + '\t:\t'.join([str(val) for val in forme]) + ''] for i, forme in enumerate(rep)]) + win = message(self, items, u"Formes associées", (300, 200)) + #win = message(self, u"Formes associées", (300, 200)) + #win.html = '\n' + '
'.join([' : '.join([str(val) for val in forme]) for forme in rep]) + '\n' + #win.HtmlPage.SetPage(win.html) win.Show(True) - - def OnPopupTwo(self, event): + + def onstcaract(self, evt) : + ind = self.menuid[evt.Id] + limite = 50 + minind = 2 activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) - item=self.getColumnText(self.list.GetFirstSelected(), 0) + item=self.getColumnText(self.GetFirstSelected(), 0) corpus = page.corpus - win = message(self, -1, u"Concordancier", size=(600, 200),style = wx.DEFAULT_FRAME_STYLE) - avap=60 - listmot = corpus.getlems()[item].formes - uce_ok = corpus.getlemuces(item) - txt = '

Concordancier

' - res = corpus.getconcorde(uce_ok) - for uce in res : - ucetxt = ' '+uce[1]+' ' - txt += ' '.join(corpus.ucis[corpus.getucefromid(uce[0]).uci].etoiles) + '
' - for forme in listmot : - forme = corpus.getforme(forme).forme - ucetxt = ucetxt.replace(' '+forme+' ', ' ' + forme + ' ') - txt += ucetxt + '

' -# for uce in uce_ok: -# content = ' '+' '.join(corpus.ucis_paras_uces[uce[0]][uce[1]][uce[2]])+' ' -# for form in listmot : -# sp = '' -# i = 0 -# forme = ' ' + form + ' ' -# while i < len(content): -# coordword = content[i:].find(forme) -# if coordword != -1 and i == 0: -# txt += '
' + ' '.join(corpus.ucis[uce[0]][0]) + '
' -# if coordword < avap: -# sp = ' ' * (avap - coordword) -# deb = i -# else: -# deb = i + coordword - avap -# if len(content) < i + coordword + avap: -# fin = len(content) - 1 -# else: -# fin = i + coordword + avap -# txt += '' + sp + content[deb:fin].replace(forme, '' + forme + '') + '
' -# i += coordword + len(forme) -# sp = '' -# elif coordword != -1 and i != 0 : -# if coordword < avap: -# sp = ' ' * (avap - coordword) -# deb = i -# else: -# deb = i + coordword - avap -# if len(content) < i + coordword + avap: -# fin = len(content) - 1 -# else: -# fin = i + coordword + avap -# txt += '' + sp + content[deb:fin].replace(forme, '' + forme + '') + '
' -# i += coordword + len(forme) -# sp = '' -# else: -# i = len(content) -# sp = '' - win.HtmlPage.SetPage(txt) + parametres = page.parametres + paneff = self.gparent.ListPanEff + panchi = self.gparent.ListPan + et = self.etoiles[ind] + uces = corpus.getucesfrometoile(et) + self.la = [panchi.dlist[i][0] for i in range(0, len(panchi.dlist)) if panchi.dlist[i][ind+1] >= minind ] + self.lchi = [panchi.dlist[i][ind+1] for i in range(0, len(panchi.dlist)) if panchi.dlist[i][ind+1] >= minind ] + if max(self.lchi) == float('inf') : + nchi = [] + for val in self.lchi : + if val == float('inf') : + nchi.append(0) + else : + nchi.append(val) + nmax = max(nchi) + nchi = [val if val != float('inf') else nmax + 2 for val in self.lchi] + self.lchi = nchi + tab = corpus.make_pondtable_with_classe(uces, self.la) + tab.pop(0) + ntab = [round(sum([(self.lchi[i] * word) for i, word in enumerate(line) if word != 0]),2) for line in tab] + ntab2 = [[ntab[i], uces[i]] for i, val in enumerate(ntab) if ntab[i] != 0] + del ntab + ntab2.sort(reverse = True) + ntab2 = ntab2[:limite] + nuces = [val[1] for val in ntab2] + ucis_txt, ucestxt = doconcorde(corpus, nuces, self.la) + items = dict([[i, '
'.join([ucis_txt[i], '
score : %.2f

' % ntab2[i][0], ucestxt[i]])] for i in range(0,len(ucestxt))]) + win = message(self, items, u"Segments de texte caractéristiques - %s" % self.first[ind], (900, 600)) win.Show(True) + + def OnPopupTwo(self, event): + if 'nb' in dir(self.parent) : + activenotebook = self.parent.nb.GetSelection() + page = self.parent.nb.GetPage(activenotebook) + corpus = page.corpus + else : + corpus = self.parent.parent.parent.corpus + ira = wx.GetApp().GetTopWindow() + item=self.getColumnText(self.GetFirstSelected(), 0) + if not self.tgen : + uce_ok = corpus.getlemuces(item) + wordlist = [item] + else : + uce_ok = corpus.gettgenst(self.tgens[item]) + wordlist = [val for val in self.tgens[item] if val in corpus.lems] + ucis_txt, ucestxt = doconcorde(corpus, uce_ok, wordlist) + items = dict([[i, '

'.join([ucis_txt[i], ucestxt[i]])] for i in range(0,len(ucestxt))]) + win = message(ira, items, u"Concordancier - %s" % item, (800, 500), uceids = uce_ok) + win.Show(True) + + def getinf(self, txt) : + if txt == float('Inf') : + return 'Inf' + elif txt == float('-Inf') : + return '-Inf' + else : + return `txt` def OnPopupThree(self, event) : - datas = [self.dlist[self.list.GetItemData(self.list.GetFirstSelected())]] - last = self.list.GetFirstSelected() - while self.list.GetNextSelected(last) != -1: - last = self.list.GetNextSelected(last) - data = self.dlist[self.list.GetItemData(last)] + datas = [self.GetItemData(self.GetFirstSelected())] + last = self.GetFirstSelected() + while self.GetNextSelected(last) != -1: + last = self.GetNextSelected(last) + data = self.GetItemData(last) datas += [data] - colnames = self.first[1:] - table = [[str(val) for val in line[1:]] for line in datas] + colnames = self.first + table = [[self.getinf(val) for val in line[1:]] for line in datas] rownames = [val[0] for val in datas] - tmpgraph = tempfile.mktemp(dir=self.parent.TEMPDIR) - - txt = barplot(table, rownames, colnames, self.parent.RscriptsPath['Rgraph'], tmpgraph) - - tmpscript = tempfile.mktemp(dir=self.parent.TEMPDIR) - file = open(tmpscript,'w') - file.write(txt) - file.close() - exec_rcode(self.parent.RPath, tmpscript, wait = True) - win = MessageImage(self, -1, u"Graphique", size=(700, 500),style = wx.DEFAULT_FRAME_STYLE) - win.addsaveimage(tmpgraph) - txt = "" % tmpgraph - win.HtmlPage.SetPage(txt) - win.Show(True) + BarFrame(self.parent, table, colnames, rownames) def OnTgen_glob(self, evt) : activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) corpus = page.corpus - tmpgraph = tempfile.mktemp(dir=self.gparent.parent.TEMPDIR) + tmpgraph = tempfile.mktemp(dir=self.parent.TEMPDIR) intxt = """ load("%s") """ % corpus.dictpathout['RData'] @@ -287,90 +338,16 @@ class ListForSpec(wx.Panel, listmix.ColumnSorterMixin): spec.Tgen.glob <- spec.Tgen.glob[[1]][((nrow(Tgen.table)-ncol(Tgen.table))+1):nrow(Tgen.table),] di <- spec.Tgen.glob """ - txt = barplot('', '', '', self.gparent.parent.RscriptsPath['Rgraph'], tmpgraph, intxt = intxt) - tmpscript = tempfile.mktemp(dir=self.gparent.parent.TEMPDIR) + txt = barplot('', '', '', self.parent.RscriptsPath['Rgraph'], tmpgraph, intxt = intxt) + tmpscript = tempfile.mktemp(dir=self.parent.TEMPDIR) with open(tmpscript, 'w') as f : f.write(txt) - exec_rcode(self.gparent.parent.RPath, tmpscript, wait = True) + exec_rcode(self.parent.RPath, tmpscript, wait = True) win = MessageImage(self, -1, u"Graphique", size=(700, 500),style = wx.DEFAULT_FRAME_STYLE) win.addsaveimage(tmpgraph) txt = "" % tmpgraph win.HtmlPage.SetPage(txt) win.Show(True) - - def OnSize(self, event): - w,h = self.GetClientSizeTuple() - self.list.SetDimensions(0, 0, w, h) - - def OnColClick(self,event): - self.do_greyline() - -class message(wx.Frame): - def __init__(self, *args, **kwds): - # begin wxGlade: MyFrame.__init__ - kwds["style"] = wx.DEFAULT_FRAME_STYLE - wx.Frame.__init__(self, *args, **kwds) - #self.text_ctrl_1 = wx.TextCtrl(self, -1, "", style=wx.TE_MULTILINE) - self.HtmlPage=wx.html.HtmlWindow(self, -1) - if "gtk2" in wx.PlatformInfo: - self.HtmlPage.SetStandardFonts() - self.HtmlPage.SetFonts('Courier','Courier') - - - self.button_1 = wx.Button(self, -1, "Fermer") - self.Bind(wx.EVT_BUTTON, self.OnCloseMe, self.button_1) - self.Bind(wx.EVT_CLOSE, self.OnCloseWindow) - self.__do_layout() - # end wxGlade - - def __do_layout(self): - # begin wxGlade: MyFrame.__do_layout - sizer_1 = wx.BoxSizer(wx.VERTICAL) - sizer_2 = wx.BoxSizer(wx.VERTICAL) - sizer_2.Add(self.HtmlPage, 1, wx.EXPAND|wx.ADJUST_MINSIZE, 0) - sizer_2.Add(self.button_1, 0, wx.ALIGN_CENTER_HORIZONTAL|wx.ADJUST_MINSIZE, 0) - sizer_1.Add(sizer_2, 1, wx.EXPAND, 0) - self.SetAutoLayout(True) - self.SetSizer(sizer_1) - self.Layout() - # end wxGlade - - def OnCloseMe(self, event): - self.Close(True) - - def OnCloseWindow(self, event): - self.Destroy() - - -def getSmallUpArrowData(): - return \ -'\x89PNG\r\n\x1a\n\x00\x00\x00\rIHDR\x00\x00\x00\x10\x00\x00\x00\x10\x08\x06\ -\x00\x00\x00\x1f\xf3\xffa\x00\x00\x00\x04sBIT\x08\x08\x08\x08|\x08d\x88\x00\ -\x00\x00C\xb0\x89\ -\xd3.\x10\xd1m\xc3\xe5*\xbc.\x80i\xc2\x17.\x8c\xa3y\x81\x01\x00\xa1\x0e\x04e\ -?\x84B\xef\x00\x00\x00\x00IEND\xaeB`\x82" - -def getSmallDnArrowBitmap(): - return wx.BitmapFromImage(getSmallDnArrowImage()) - -def getSmallDnArrowImage(): - stream = cStringIO.StringIO(getSmallDnArrowData()) - return wx.ImageFromStream(stream) + + def OnMakeTgen(self, evt): + self.parent.tree.OnTgenEditor(self.getselectedwords())