自制Python函数帮助查询小工具

开发 后端 前端
鉴于此,我决定自己做一个小工具,花费较小的系统代价来方便的查询各种函数和模组的功能。这里只给出一个能使用的版本。开放源代码给大家,代码风格和控件设计可供初学者模仿。

Python的自带文档功能很不错,给与我耳目一新的感觉。如果在CMD中进行“行式编程”编程的话,可以随时随地的查询函数的功能,非常方便。比如在学习list、tuple、dict、str、os、sys等模组的时候,利用Python的自带文档可以很快速的全面的学到那些处理的函数。所以这个自带文档功能能够给出学者带来很大的方便之处,进行简短的开发是再好不过的。

但是,当你离开CMD,要利用IDLE或者要用Komodo Edit等软件进行“段式编程”的时候,就有些捉襟见肘了。例如,wx库非常之大,帮助文件有10MB之多,如果你在CMD中打开,你可以想想你需要多少时间才能够查看到你想要的帮助信息。大规模的熟悉Python的各种API之后,你会发现,这个并不是想象的那么好用。不断的按任意键进行翻页,同时页面内能够容纳的页面也有限。所以表现出非常大的不便之处。

这里大概有两种方法解决。

***,使用Module Docs工具

这个工具是Python GUI IDLE自带的一个查询帮助文件的方法。在里面可以利用网页的形式,利用本机的本地功能,提供一个模拟在线的一个查询方法。它可以打开一个网页,上面可以显示出所有的函数,并带有规范的分类,比较清楚,但是使用起来还是不方便,毕竟没有搜索功能。如果将查到的网页内容保存链接,那么是不可以持续使用的。所以这个就有很大的问题,同时,其生成的网页文件巨大,内存太小是会给系统带来压力。所以这个方法并不是一个可以很方便使用的方法。

第二,自己开发工具

其实我也不愿意自己开发工具,因为这个毕竟需要时间,几天时间或者几个周的时间说少也少,说多也多,而且给自己的内心产生的压力也不小,毕竟需要分心不少来做这个事情。我在网上找了很长时间,都没有找到,对于wx,我找到一个wxPython API的英文文档,上面介绍的很不清楚,非常模糊,直接列出了函数和具体的参数,如何使用基本很少提及,而且很多控件的各种style也没有详细列举出来。所以是很不好用的,如果是名字忘掉了,那还可以查一下完整的单词和详细的参数列表。其他的功能就完全很少涉及到了。

鉴于此,我决定自己做一个小工具,花费较小的系统代价来方便的查询各种函数和模组的功能。这里只给出一个能使用的版本。开放源代码给大家,代码风格和控件设计可供初学者模仿。高手愿意来批评我,我洗耳恭听。后续版本也会发布在这里,到时候可能就先封装之后在发布,现在发布的这个是源代码文件,大家都知道,Python的源代码文件双击即可执行。

#coding=utf-8  
#功能介绍:本软件最初只用于模块和函数用法的查询,进行快速的显示  
#扩展功能:可以将查询成功的结果保存到本地,  
#          将里面的部分函数使用汉语进行注释之后的结果保存下来  
#          以保存的关键字放于右侧列表  
#深度扩展:使用数据库保存结果,并提供增删查改的接口  
 
from Tkinter import *  
from StringIO import StringIO  
from tkSimpleDialog import *  
import sys  
import Pmw  
import ConfigParser  
import os  
import wx  
 
class Finder(Frame):  
 
    def OnFind(self):  
        #执行,并获取结果  
        info = self.inputStr.get()  
        if len(info)==0:  
            return True 
        buff =StringIO()  
        temp = sys.stdout    #保存标准I/O流  
        sys.stdout = buff    #将标准I/O流重定向到buff对象  
        self.text.delete(1.0, END)  
        try:  
            fmt = 'help('+info+')' 
            result = eval(fmt)  
            self.text.insert(1.0, buff.getvalue())  
            self.savebtn.config(state=NORMAL)  
        except:  
            try:  
                __import__(info)  
 
                fmt = 'help('+self.inputStr.get()+')' 
                result = eval(fmt)  
                self.text.insert(1.0, buff.getvalue())  
            except:  
                self.text.insert(1.0,"ERROR.")  
        sys.stdout =temp     #恢复标准I/O流buff.getvaue()  
        self.helpbtn.config(state=NORMAL)  
 
         
    def save(self):  
        #搜索,如果没有找到就保存,使用ini文件进行,保存数据  
        #保存原始  
        tofind = self.inputStr.get()  
        if len(tofind)==0:  
            return 
        filename='s_'+tofind+'.ini' 
        fout = open(filename,'w')  
        fout.write(self.text.get(1.0, END).encode('utf-8'))  
        fout.close()  
          
        self.items.append(tofind)  
        self.items.sort()  
        self.config.add_section(tofind)  
        self.config.write(open('data.ini''r+'))  
          
        nindex = self.items.index(tofind)  
        self.box.delete(0,END)  
        self.box.insert(0, *self.items)  
        self.box.see(nindex)  
        self.box.selection_set(nindex)  
 
        self.savebtn.config(state=DISABLED)  
 
    def saveas(self):  
        #保存修改  
        index = self.box.curselection()   
        if index<0:  
            return             
        tofind = self.box.get(index)  
        if len(tofind)==0:  
            return 
        strinfo = self.text.get(1.0, END)  
 
        filename='s_'+tofind+'.ini' 
        fout = open(filename,'w')  
        fout.write(strinfo.encode("UTF-8"))  
        fout.close()    
 
        self.saveasbtn.config(state=DISABLED)  
 
    def __init__(self):  
        Frame.__init__(self)  
        self.option_add('*Font''Verdana 12 bold')  
        self.pack(expand=YES, fill=BOTH)  
        self.master.title(u'Python函数查询器')  
        self.master.iconname("calc1")  
 
        #左侧列表,放置已保存的条目,按照字母顺序排序  
        infoF = Frame(self)  
        infoF.pack(side=LEFT,expand=NO, fill=BOTH)  
 
        listF = Frame(infoF)  
        listF.pack(side=TOP,expand=YES, fill=BOTH)  
 
        #获取项目  
        self.config = ConfigParser.ConfigParser()  
        self.config.read('data.ini')  
        self.items = self.config.sections()  
        self.items.sort()  
        self.box = Listbox(listF,width=15,selectmode=SINGLE)  
        self.box.insert(0, *self.items)  
        self.box.bind('<ButtonRelease-1>',self.selectionCommand)#使用鼠标释放消息  
        self.box.bind('<ButtonRelease-3>',self.boxrightmenu)#使用右键菜单删除项目  
 
        self.PopupMenu=Menu(listF)  
        self.PopupMenu.add_command(label=u'删除',command=self.deleteitem)  
        self.PopupMenu.add_command(label=u'重命名',command=self.renameitem)  
        self.box.pack(side=LEFT,expand=YES,fill=BOTH)  
          
        self.slbar = Scrollbar(listF, orient=VERTICAL, command=self.box.yview)  
        self.slbar.pack(side=RIGHT, expand=NO, fill=BOTH)  
        self.box.configure(yscrollcommand=self.slbar.set)  
          
        btnf = Frame(infoF)  
        btnf.pack(side=BOTTOM, fill=BOTH)  
        self.savebtn = Button(btnf, text=u'新建保存',state=DISABLED, command=self.save)  
        self.savebtn.pack(side=LEFT, expand=YES, fill=BOTH)          
        self.saveasbtn = Button(btnf, text=u'保存修改',state=DISABLED, command=self.saveas)  
        self.saveasbtn.pack(side=RIGHT, expand=YES, fill=BOTH)  
 
 
        #包括列表信息和显示信息  
        twoF = Frame(self)  
        twoF.pack(side=BOTTOM, expand=YES, fill=BOTH)  
          
        #显示信息、滚动条  
        showF = Frame(twoF, relief=SUNKEN)  
        self.text = Text(showF,height=25, width =65)  
        self.text.insert(1.0,'information...')  
        self.text.pack(side=LEFT, expand=YES, fill=BOTH)     
        self.text.bind("<Key>"self.modify)    
        self.text.bind("<Double-Button-1>"self.tomodify)  
        self.ismodified = False 
        showF.pack(side=TOP,expand=YES, fill=BOTH)  
 
        self.scrollbar = Scrollbar(showF, orient=VERTICAL, command=self.text.yview)  
        self.scrollbar.pack(side=RIGHT, expand=NO, fill=BOTH)  
        self.text.configure(yscrollcommand=self.scrollbar.set)  
 
        #提供输入接口,和功能如:查找  
        inputF = Frame(twoF)  
        inputF.pack(side=BOTTOM, fill=BOTH)  
        self.inputStr = StringVar()  
        self.inputStr.set('')  
        self.info = StringVar()  
        self.info.set('infomation...')  
        self.entry = Entry(inputF, relief=SUNKEN, textvariable=self.inputStr)  
        self.entry.bind("<Return>"self.inputreturn)  
        self.entry.pack(side=LEFT, expand=YES, fill=BOTH)  
          
        self.findbtn = Button(inputF,text=u'查找',command=self.OnFind)  
        self.findbtn.pack(side=LEFT, expand=YES, fill=BOTH)  
        self.helpbtn = Button(inputF,text=u'帮助',command=self.OnHelp)  
        self.helpbtn.pack(expand=NO, fill=Y)  
 
    def OnHelp(self):  
        fp = open('readme.txt')  
        buff = fp.read()  
        fp.close()  
 
        self.text.delete(1.0, END)  
        self.text.insert(1.0, buff)     
        self.helpbtn.config(state=DISABLED)  
 
    def deleteitem(self):  
        #右键菜单, 删除功能  
        sels = self.box.curselection()  
        if len(sels) == 0:  
            pass #print 'no selection'  
        else:  
            sec = self.items[int(sels[0])]  
            self.config.remove_section(sec)  
            self.config.write(open('data.ini''w'))  
            self.box.delete(sels[0])  
     #       self.items.remove(sels[0])     #是引用效果  
            self.text.delete(1.0, END)  
            self.text.insert(1.0,'delete success.')  
              
 
    def renameitem(self,event=None,en=None):  
        #邮件菜单, 重命名功能  
        retval = askstring("input",  
                    "input the new name:")  
        if len(retval)==0:  
            return 
        sels = self.box.curselection()  
        if len(sels) == 0:  
            pass #print 'no selection'  
        else:  
            #数组/表/配置文件  
            sec = self.items[int(sels[0])]  
 
            self.box.delete(0, END)  
            self.items[int(sels[0])] = retval    #数组  
            self.items.sort()  
            self.box.insert(0, *self.items)     #表  
              
            self.config.remove_section(sec)  
            self.config.add_section(retval)  
            self.config.write(open('data.ini''w'))    #配置文件  
              
            self.text.delete(1.0, END)  
            self.text.insert(1.0,'rename success.')  
              
      
    def boxrightmenu(self,event=None,en=None):  
        #弹出右键菜单  
        self.PopupMenu.tk_popup(*self.winfo_pointerxy())  
      
    def tomodify(self,event=None,en=None):  
        if self.ismodified==True:  
            self.saveasbtn.config(state=DISABLED)  
            self.ismodified = False 
        else:  
            self.saveasbtn.config(state=NORMAL)  
            self.ismodified = True 
        return True 
      
    def modify(self,event=None,en=None):              
        self.saveasbtn.config(state=NORMAL)  
        return True 
 
    def inputreturn(self,event=None,en=None):  
        self.OnFind()  
        return True 
          
    def selectionCommand(self,event=None,en=None):  
        # 选中列表时, 显示详细内容  
        sels = self.box.curselection()  
        if len(sels) == 0:  
            pass   
        else:  
            filename='s_'+self.box.get(sels[0])+'.ini' 
            fp = open(filename)  
            strinfo = fp.read()  
            fp.close()  
            self.text.delete(1.0, END)  
            self.text.insert(1.0,strinfo)  
        self.helpbtn.config(state=NORMAL)  
 
if __name__ == '__main__':  
    Finder().mainloop()  
  • 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.
  • 109.
  • 110.
  • 111.
  • 112.
  • 113.
  • 114.
  • 115.
  • 116.
  • 117.
  • 118.
  • 119.
  • 120.
  • 121.
  • 122.
  • 123.
  • 124.
  • 125.
  • 126.
  • 127.
  • 128.
  • 129.
  • 130.
  • 131.
  • 132.
  • 133.
  • 134.
  • 135.
  • 136.
  • 137.
  • 138.
  • 139.
  • 140.
  • 141.
  • 142.
  • 143.
  • 144.
  • 145.
  • 146.
  • 147.
  • 148.
  • 149.
  • 150.
  • 151.
  • 152.
  • 153.
  • 154.
  • 155.
  • 156.
  • 157.
  • 158.
  • 159.
  • 160.
  • 161.
  • 162.
  • 163.
  • 164.
  • 165.
  • 166.
  • 167.
  • 168.
  • 169.
  • 170.
  • 171.
  • 172.
  • 173.
  • 174.
  • 175.
  • 176.
  • 177.
  • 178.
  • 179.
  • 180.
  • 181.
  • 182.
  • 183.
  • 184.
  • 185.
  • 186.
  • 187.
  • 188.
  • 189.
  • 190.
  • 191.
  • 192.
  • 193.
  • 194.
  • 195.
  • 196.
  • 197.
  • 198.
  • 199.
  • 200.
  • 201.
  • 202.
  • 203.
  • 204.
  • 205.
  • 206.
  • 207.
  • 208.
  • 209.
  • 210.
  • 211.
  • 212.
  • 213.
  • 214.
  • 215.
  • 216.
  • 217.
  • 218.
  • 219.
  • 220.
  • 221.
  • 222.
  • 223.
  • 224.
  • 225.
  • 226.
  • 227.
  • 228.
  • 229.
  • 230.
  • 231.
  • 232.
  • 233.
  • 234.
  • 235.
  • 236.
  • 237.
  • 238.
  • 239.
  • 240.
  • 241.
  • 242.
  • 243.
  • 244.
  • 245.
  • 246.
  • 247.
  • 248.

注意事项,源代码文件如果想要正确执行,请自己建立一个readme.txt文件,和data.ini文件。否则将会因为这两个文件打不开而出错。为什么没有使用异常处理呢?我没有没有完善到那一步。现在这个版本已经可以使用了,所以大家不防试试看。

【注意】:打开软件后,请输入list、tuple、dict等类型进行查询,点击新建保存即可保存到列表,供下次快速打开。

有的包在源代码中没有包括,如codecs。这个时候你需要手动的将这个包添加到源文件的开头,才能够查询到,如:import codecs。

如果你修改了显示框中的文本,请及时点击保存修改进行保存,以便下次打开还可以看到你修改的效果。

本版本并不完善,而且功能有限,本身基于Python做的,所以其价值还是作为Python开发应用实例为主。
 

原文链接:http://www.cnblogs.com/Hiker/archive/2011/03/09/funfind.html

【编辑推荐】

  1. 巧用IronPython做更灵活的网页爬虫
  2. Python 3.2发布 改进调试器PDB
  3. 浅谈Python Web的五大框架
  4. 一个Python程序员的进化
  5. 年度黑马Python 自省指南
责任编辑:陈贻新 来源: 布同的博客
相关推荐

2019-06-24 09:55:32

MySQLSQL优化

2009-11-19 08:48:10

Windows 7桌面工具

2010-07-01 10:24:30

UML小工具

2009-12-08 14:02:25

Windows 7小工

2021-05-10 11:06:31

Python工具代码

2020-11-26 12:05:44

Python小工具代码

2021-05-20 11:30:17

Python工具代码

2019-11-01 11:12:50

PythonExcelWindows

2022-03-30 15:11:26

Python房价工具

2013-03-29 14:46:33

App开发小工具辅助工具

2022-12-28 12:29:45

duf命令

2009-07-07 08:49:33

微软Windows 7新功能

2013-12-16 17:25:08

KDEGNOME桌面应用

2022-05-31 09:42:49

工具编辑器

2017-07-25 14:20:13

戴尔配置功耗

2021-11-05 06:57:50

架构工具代码

2010-05-19 19:10:42

2011-04-12 12:53:17

2011-11-30 16:31:00

TimZon

2022-06-08 12:10:56

canvasvue.js
点赞
收藏

51CTO技术栈公众号