X-Git-Url: http://iramuteq.org/git?p=iramuteq;a=blobdiff_plain;f=listlex.py;h=c3a723468936dd99da399cee931029395175ba13;hp=5d34a66b9afa356ba2f20f7a21741777ba65b14c;hb=342d693d835ba1077fe0f31824664a807cafa3bb;hpb=a503f041dc4947ee21c1d353ddd05ddb13a5e322 diff --git a/listlex.py b/listlex.py index 5d34a66..c3a7234 100644 --- a/listlex.py +++ b/listlex.py @@ -21,22 +21,18 @@ import tempfile from functions import exec_rcode, MessageImage from chemins import ffr from PrintRScript import barplot -from dialog import SearchDial +from dialog import SearchDial, message +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.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSorterMixin): - def __init__(self, parent,gparent, dlist,first): + def __init__(self, parent,gparent, dlist, first, menu = True): 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 search_id = wx.NewId() self.parent.Bind(wx.EVT_MENU, self.onsearch, id = search_id) @@ -59,35 +55,41 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor self.dlist = dlist - self.Bind(wx.EVT_LIST_ITEM_SELECTED, self.OnItemSelected, self) - - # for wxMSW - self.Bind(wx.EVT_COMMAND_RIGHT_CLICK, self.OnRightClick) + i=0 + for name in first : + self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) + i+=1 + + self.SetColumnWidth(0, 180) - # for wxGTK - self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) - + for i in range(1,len(first)-1): + self.SetColumnWidth(i, self.checkcolumnwidth(len(first[i]) * 10)) self.itemDataMap = dlist self.itemIndexMap = dlist.keys() self.SetItemCount(len(dlist)) - listmix.ListCtrlAutoWidthMixin.__init__(self) + #listmix.ListCtrlAutoWidthMixin.__init__(self) listmix.ColumnSorterMixin.__init__(self, len(first)) - self.SortListItems(1, False) + 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) - i=0 - for name in first : - self.InsertColumn(i,name,wx.LIST_FORMAT_LEFT) - i+=1 - - self.SetColumnWidth(0, 180) + # for wxGTK + self.Bind(wx.EVT_RIGHT_UP, self.OnRightClick) - for i in range(1,len(first)-1): - self.SetColumnWidth(i, len(first[i]) * 10) +#----------------------------------------------------------------------------------------- + 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] @@ -107,8 +109,7 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor # 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() @@ -127,7 +128,14 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor 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() @@ -139,40 +147,48 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor 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.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() + + 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.getColumnText(self.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) + 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) @@ -182,7 +198,7 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor page = self.parent.nb.GetPage(activenotebook) item=self.getColumnText(self.GetFirstSelected(), 0) corpus = page.corpus - win = message(self, -1, u"Concordancier", size=(600, 200),style = wx.DEFAULT_FRAME_STYLE) + win = message(self, u"Concordancier", (750, 600)) avap=60 listmot = corpus.getlems()[item].formes uce_ok = corpus.getlemuces(item) @@ -198,28 +214,31 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor win.HtmlPage.SetPage(txt) 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) : - print self.GetFirstSelected() datas = [self.GetItemData(self.GetFirstSelected())] - print datas 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] + 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() + 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 = MessageImage(self, u"Graphique", size=(700, 500)) win.addsaveimage(tmpgraph) txt = "" % tmpgraph win.HtmlPage.SetPage(txt) @@ -258,46 +277,3 @@ class ListForSpec(wx.ListCtrl, listmix.ListCtrlAutoWidthMixin, listmix.ColumnSor txt = "" % tmpgraph win.HtmlPage.SetPage(txt) win.Show(True) - - def SortItems(self,sorter=cmp): - items = list(self.itemDataMap.keys()) - items.sort(sorter) - self.itemIndexMap = items - # redraw the list - self.Refresh() - -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()