# -*- coding: utf-8 -*- #---------------------------------------------------------------------------- # Author: Pierre Ratinaud # #comes from ListCtrl.py from the demo tool of wxPython: # Author: Robin Dunn & Gary Dumer # # Created: # Copyright: (c) 1998 by Total Control Software # Licence: wxWindows license #---------------------------------------------------------------------------- import os import sys import wx import wx.lib.mixins.listctrl as listmix import cStringIO import tempfile from functions import exec_rcode, MessageImage, doconcorde from chemins import ffr from PrintRScript import barplot from dialog import SearchDial, message from operator import itemgetter #--------------------------------------------------------------------------- class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSorterMixin): def __init__(self, parent,gparent, dlist, first, 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 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) 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.attr1 = wx.ListItemAttr() self.attr1.SetBackgroundColour((230, 230, 230)) self.attr2 = wx.ListItemAttr() self.attr2.SetBackgroundColour("light blue") i=0 for name in self.first : self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) i+=1 self.SetColumnWidth(0, 180) for i in range(1,len(self.first)-1): self.SetColumnWidth(i, self.checkcolumnwidth(len(self.first[i]) * 10)) self.itemDataMap = self.dlist self.itemIndexMap = self.dlist.keys() self.SetItemCount(len(self.dlist)) #listmix.ListCtrlAutoWidthMixin.__init__(self) listmix.ColumnSorterMixin.__init__(self, len(self.first)) self.SortListItems(1, 0) #----------------------------------------------------------------------------------------- self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) # for wxMSW self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) # for wxGTK self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) #----------------------------------------------------------------------------------------- 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 item % 2 : return self.attr1 else : return self.attr2 # Used by the ColumnSorterMixin, see wx/lib/mixins/listctrl.py def GetListCtrl(self): 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.HitTest((x, y)) if flags & wx.LIST_HITTEST_ONITEM: self.Select(item) event.Skip() def getColumnText(self, 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() def onsearch(self, evt) : self.dial = SearchDial(self, self, 0, True) self.dial.CenterOnParent() self.dial.Show() #self.dial.Destroy() def OnRightClick(self, event): 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.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.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, "Graphique") menu_stcaract = wx.Menu() self.menuid = {} for i, et in enumerate(self.first[1:]) : 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") 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, 1)) return words def OnPopupOne(self, event): activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) corpus = page.corpus word = self.getselectedwords()[0] lems = corpus.getlems() rep = [] for forme in lems[word].formes : rep.append([corpus.getforme(forme).forme, corpus.getforme(forme).freq]) rep.sort(key = itemgetter(1), reverse = True) 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 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.GetFirstSelected(), 0) corpus = page.corpus parametres = page.parametres paneff = self.gparent.ListPanEff panchi = self.gparent.ListPan et = self.first[ind+1] if et.startswith(u'X.') : et = et.replace(u'X.', u'*') 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 ] #lfreq = [paneff.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) win = message(self, u"Segments de texte caractéristiques - %s" % self.first[ind], (750, 600)) win.html = '\n' + '
'.join(['
'.join([ucis_txt[i], '
score : %.2f
' % ntab2[i][0], ucestxt[i]]) for i in range(0,len(ucestxt))]) + '\n' win.HtmlPage.SetPage(win.html) #dlg.Destroy() win.Show(True) def OnPopupTwo(self, event): activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) item=self.getColumnText(self.GetFirstSelected(), 0) corpus = page.corpus uce_ok = corpus.getlemuces(item) win = message(self, u"Concordancier", (750, 600)) ucis_txt, ucestxt = doconcorde(corpus, uce_ok, [item]) win.html = ('\n

%s

' % item) + '
'.join(['
'.join([ucis_txt[i], ucestxt[i]]) for i in range(0,len(ucestxt))]) + '\n' win.HtmlPage.SetPage(win.html) 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.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 = [[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) with open(tmpscript,'w') as f : f.write(txt) exec_rcode(self.parent.RPath, tmpscript, wait = True) win = MessageImage(self, u"Graphique", size=(700, 500)) win.addsaveimage(tmpgraph) txt = "" % tmpgraph win.HtmlPage.SetPage(txt) win.Show(True) def OnTgen_glob(self, evt) : activenotebook = self.parent.nb.GetSelection() page = self.parent.nb.GetPage(activenotebook) corpus = page.corpus tmpgraph = tempfile.mktemp(dir=self.parent.TEMPDIR) intxt = """ load("%s") """ % corpus.dictpathout['RData'] intxt += """ Tgen.glob = NULL tovire <- NULL for (i in 1:ncol(dmf)) { Tgen.glob <- rbind(Tgen.glob,colSums(dmf[which(specf[,i] > 3),])) tovire <- append(tovire, which(specf[,i] > 3)) } rownames(Tgen.glob) <- colnames(dmf) Tgen.table <- dmf[-unique(tovire),] Tgen.table<- rbind(Tgen.table, Tgen.glob) spec.Tgen.glob <- AsLexico2(Tgen.table) spec.Tgen.glob <- spec.Tgen.glob[[1]][((nrow(Tgen.table)-ncol(Tgen.table))+1):nrow(Tgen.table),] di <- spec.Tgen.glob """ 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.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)