哪位大佬给看看还能不能优化一下?

2022-07-30 19:13:40 +08:00
 tankren
代码地址:
https://github.com/tankren/GoldenTax_Djh_Autofill/blob/main/Auto_mapping.py
如题,非码农,帮财务部写的一个小工具,背景是金税系统导出 xml 单据号字段缺失。打帮助热线只会让你花几万上云系统...
逻辑是从批量导入结果 txt 里面查找并填充。
还有就是用 pyinstaller 打包失败,后来换的 niutka ,可以成功运行,体积高达 30m 是否正常?
1831 次点击
所在节点    Python
7 条回复
blankmiss
2022-07-30 20:35:16 +08:00
python 的包好像都挺大的 没有示例文件(脱敏) 也不知道你是哪里出问题
tankren
2022-07-30 21:45:58 +08:00
@blankmiss #1 运行没啥问题,完全达到预期要求。就是我不知道这样写是不是符合规范,有没有什么需要改进的地方。这个是我一边 Google 一边写的。。。
neptuno
2022-07-30 22:37:01 +08:00
我是写 java 的,python 忘得差不多了,提一点建议:1 、可以用多线程处理数据,2 、for 循环里面 import re 是不是不符合规范,应该在代码最前面引入吧 3 、for 循环里面是不是可以只写读取的逻辑,把需要写入的放入 list ,最后一次性写入
tankren
2022-07-31 00:12:39 +08:00
@neptuno #3 感谢建议
ranleng
2022-07-31 11:51:04 +08:00
如果说规范的话,代码可以用 black 等工具格式化下。
用了 logging 就不需要 print 了,况且 logging 可以控制输出等级 (INFO, DEBUG etc..)
for 循环嵌套层数有点多,可以拆成不同的函数
re.compile 可以放在循环外(因为只需要 compile 一次
pattern.findall(line)[0] 可能会报错,比如匹配不到内容的时候
if map == '': 可以直接写成 if not map:
tankren
2022-07-31 16:21:40 +08:00
@ranleng #5 感谢,回头我试试,特别是匹配为空的处理优化
tankren
2022-08-01 19:52:15 +08:00
@ranleng 大佬,今天有空撸了一个 GUI 版本,用的 PySide6 ,能麻烦瞅瞅吗?
https://github.com/tankren/GoldenTax_Djh_Autofill/blob/main/Mapping_GUI.py
另外有一个打包的问题,还是用 Nuitka 打包,可以正常运行,但是窗体图标没有了,调试的时候或者非单文件打包都能正常显示,但 onefile 就看不到我定义的图标,从 onefile 自己解包的 temp 目录运行也能显示图标,查不到相关的资料。
ps: nuitka 我加了--include-data-files 参数。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/869677

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX