如何在IDLE中加入中文帮助文件
本帖最后由 txxcat 于 2020-2-29 21:09 编辑Python的帮助文档是英文的,对于英语不大好,例如本人来说,看着头疼,免不了要用翻译软件,费时费力还经常不得要领,不过好在现在有官方汉化的中文文档了,虽然现在还不全,但基本的内容都已经汉化了,深入的汉化工作还在不断进行中,加油吧!
Python中文文档地址:Python官方中文文档
文档可以打包下载,不过速度嘛,比没会员的百度网盘还要慢,所以这里提供百度网盘的下载:
PDF版:
链接:PDF版百度网盘下载
提取码:ixf2
HTML版:
链接:HTML版百度网盘下载
提取码:foq4
准备工作结束了,现在就是怎么把IDLE中的帮助文档换成中文版的,一开始的想法是把HTML的文档编译成CHM文件,然后取而代之,结果用了几个CHM编译工具,编译出来的文件打开不停报错,排版混乱,根本不能用,如果是纯windows应用,到此就是死路一条,除非你找到程序员帮你,但是这个是python呀,无所不能、无限可能的Pyhton,IDLE都是用python写出来的,那就自己动手,丰衣足食吧。
首先,弄清楚python的安装文件夹在哪儿,输入以下代码获得文件夹,如果你很熟悉就跳过这一步了吧。
import sys
sys.base_prefix
'C:\\Users\\Txxcat\\AppData\\Local\\Programs\\Python\\Python38'
然后就是把HTML解压到文件夹下的Docs下,当然你可以把文档放到你喜欢的任何地方都可以,后面改写代码时指定好位置就行。
接着就是修改IDLE的代码了,最简单的方法就是把打开CHM的代码改成打开HTML,这样做可以做到最小的修改量,不过我选择保留打开原始英文文档的菜单,增加一个打开中文文档的菜单,需要多修改几个地方,我想学python的朋友应该不会嫌这个麻烦吧。
IDLE在主文件夹下的Lib\idlelib下,这里需要修改三个文件,建议先备份这几个文件,以防不小心改错了IDLE启动不了:
mainmenu.py : 菜单文件,加入打开中文文档的菜单。
搜索关键字:python-docs,找到后:
('Python _Docs', '<<python-docs>>'),
('Python _Docs_CN', '<<python-docs-cn>>'), #增加这一行增加一个菜单
config.py : 配置文件,加入打开中文菜单的快捷键,不喜欢用快捷键的可以忽略这一步。
搜索关键字:python-docs,找到后:
'<<python-docs>>': ['<F1>'],
'<<python-docs-cn>>': ['<F2>'],#增加这行把F2指定为打开中文文档的快捷键
editor.py :IDLE的主文件,这里的修改量稍微多一点。
还是搜索关键字:python-docs,找到的第一项是Linux系统下运行的代码,可以看出Linux下只要替换原始文档就可以了,根本无需修改IDLE:(。往下的”elif sys.platform[:3] == 'win'“就是windows的代码了,我们这样修改:
elif sys.platform[:3] == 'win':
chmfile = os.path.join(sys.base_prefix, 'Doc',
'Python%s.chm' % _sphinx_version())
if os.path.isfile(chmfile):
dochome = chmfile
dochome2 = os.path.join(sys.base_prefix, 'Doc','index.html') #增加这一行把中文文档的主文件赋值给dochome2
elif sys.platform == 'darwin':
# documentation may be stored inside a python framework
dochome = os.path.join(sys.base_prefix,
'Resources/English.lproj/Documentation/index.html')
dochome = os.path.normpath(dochome)
dochome2 = os.path.normpath(dochome2) #增加这一行
if os.path.isfile(dochome2): #增加这个判断,如果没有中文文档,就打开官网中文版
EditorWindow.help_url2 = dochome2
else:
EditorWindow.help_url2 = ("https://docs.python.org//zh-cn/3/")
继续搜索关键字:python-docs,找到后:
text.bind("<<python-docs>>", self.python_docs)
text.bind("<<python-docs-cn>>", self.python_docs_cn)#增加这行
然后搜索关键字:python_docs,记住是下杠,找到python_docs的函数后增加一个python_docs_cn的函数:
def python_docs_cn(self, event=None):
if sys.platform[:3] == 'win':
try:
os.startfile(self.help_url2)
except OSError as why:
tkMessageBox.showerror(title='Document Start Failure',
message=str(why), parent=self.text)
else:
webbrowser.open(self.help_url2)
return "break"
然后保存,重新打开IDLE,可以看到Help菜单里增加了一项:
选择之后就会打开python的中文文档,如果以后版本更迭,网速还可以的话,可以直接删除Doc下的index.html文件,然后直接打开的就是官网最新的中文文档了。
建议写一行,空一行。 一个账号 发表于 2020-2-27 16:42
建议写一行,空一行。
谢谢建议,重新排版了,等审核了看效果。 本帖最后由 _2_ 于 2020-3-19 13:43 编辑
改成Windows的帮助文档或许更好一些,不用再打开浏览器了 就是找不到合适的CHM编译器啊{:10_243:} 爱了{:10_256:}
页:
[1]