pyxllib 0.3.96__py3-none-any.whl → 0.3.200__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (358) hide show
  1. pyxllib/__init__.py +21 -21
  2. pyxllib/algo/__init__.py +8 -8
  3. pyxllib/algo/disjoint.py +54 -54
  4. pyxllib/algo/geo.py +541 -529
  5. pyxllib/algo/intervals.py +964 -964
  6. pyxllib/algo/matcher.py +389 -311
  7. pyxllib/algo/newbie.py +166 -166
  8. pyxllib/algo/pupil.py +629 -461
  9. pyxllib/algo/shapelylib.py +67 -67
  10. pyxllib/algo/specialist.py +241 -240
  11. pyxllib/algo/stat.py +494 -458
  12. pyxllib/algo/treelib.py +149 -149
  13. pyxllib/algo/unitlib.py +66 -66
  14. {pyxlpr → pyxllib/autogui}/__init__.py +5 -5
  15. pyxllib/autogui/activewin.py +246 -0
  16. pyxllib/autogui/all.py +9 -0
  17. pyxllib/{ext/autogui → autogui}/autogui.py +852 -823
  18. pyxllib/autogui/uiautolib.py +362 -0
  19. pyxllib/{ext/autogui → autogui}/virtualkey.py +102 -102
  20. pyxllib/autogui/wechat.py +827 -0
  21. pyxllib/autogui/wechat_msg.py +421 -0
  22. pyxllib/autogui/wxautolib.py +84 -0
  23. pyxllib/cv/__init__.py +5 -5
  24. pyxllib/cv/expert.py +267 -267
  25. pyxllib/cv/imfile.py +159 -159
  26. pyxllib/cv/imhash.py +39 -39
  27. pyxllib/cv/pupil.py +9 -9
  28. pyxllib/cv/rgbfmt.py +1525 -1525
  29. pyxllib/cv/slidercaptcha.py +137 -0
  30. pyxllib/cv/trackbartools.py +251 -251
  31. pyxllib/cv/xlcvlib.py +1040 -1040
  32. pyxllib/cv/xlpillib.py +423 -423
  33. pyxllib/data/echarts.py +240 -129
  34. pyxllib/data/jsonlib.py +89 -0
  35. pyxllib/data/oss.py +72 -72
  36. pyxllib/data/pglib.py +1127 -643
  37. pyxllib/data/sqlite.py +568 -341
  38. pyxllib/data/sqllib.py +297 -297
  39. pyxllib/ext/JLineViewer.py +505 -492
  40. pyxllib/ext/__init__.py +6 -6
  41. pyxllib/ext/demolib.py +246 -246
  42. pyxllib/ext/drissionlib.py +277 -0
  43. pyxllib/ext/kq5034lib.py +12 -1606
  44. pyxllib/ext/old.py +663 -663
  45. pyxllib/ext/qt.py +449 -449
  46. pyxllib/ext/robustprocfile.py +497 -0
  47. pyxllib/ext/seleniumlib.py +76 -76
  48. pyxllib/ext/tk.py +173 -173
  49. pyxllib/ext/unixlib.py +827 -826
  50. pyxllib/ext/utools.py +351 -338
  51. pyxllib/ext/webhook.py +124 -101
  52. pyxllib/ext/win32lib.py +40 -40
  53. pyxllib/ext/wjxlib.py +88 -0
  54. pyxllib/ext/wpsapi.py +124 -0
  55. pyxllib/ext/xlwork.py +9 -0
  56. pyxllib/ext/yuquelib.py +1105 -173
  57. pyxllib/file/__init__.py +17 -17
  58. pyxllib/file/docxlib.py +761 -761
  59. pyxllib/file/gitlib.py +309 -309
  60. pyxllib/file/libreoffice.py +165 -0
  61. pyxllib/file/movielib.py +148 -139
  62. pyxllib/file/newbie.py +10 -10
  63. pyxllib/file/onenotelib.py +1469 -1469
  64. pyxllib/file/packlib/__init__.py +330 -293
  65. pyxllib/file/packlib/zipfile.py +2441 -2441
  66. pyxllib/file/pdflib.py +426 -426
  67. pyxllib/file/pupil.py +185 -185
  68. pyxllib/file/specialist/__init__.py +685 -685
  69. pyxllib/file/specialist/dirlib.py +799 -799
  70. pyxllib/file/specialist/download.py +193 -186
  71. pyxllib/file/specialist/filelib.py +2829 -2618
  72. pyxllib/file/xlsxlib.py +3131 -2976
  73. pyxllib/file/xlsyncfile.py +341 -0
  74. pyxllib/prog/__init__.py +5 -5
  75. pyxllib/prog/cachetools.py +64 -0
  76. pyxllib/prog/deprecatedlib.py +233 -233
  77. pyxllib/prog/filelock.py +42 -0
  78. pyxllib/prog/ipyexec.py +253 -253
  79. pyxllib/prog/multiprogs.py +940 -0
  80. pyxllib/prog/newbie.py +451 -444
  81. pyxllib/prog/pupil.py +1197 -1128
  82. pyxllib/prog/sitepackages.py +33 -33
  83. pyxllib/prog/specialist/__init__.py +391 -217
  84. pyxllib/prog/specialist/bc.py +203 -200
  85. pyxllib/prog/specialist/browser.py +497 -488
  86. pyxllib/prog/specialist/common.py +347 -347
  87. pyxllib/prog/specialist/datetime.py +199 -131
  88. pyxllib/prog/specialist/tictoc.py +240 -241
  89. pyxllib/prog/specialist/xllog.py +180 -180
  90. pyxllib/prog/xlosenv.py +108 -101
  91. pyxllib/stdlib/__init__.py +17 -17
  92. pyxllib/stdlib/tablepyxl/__init__.py +10 -10
  93. pyxllib/stdlib/tablepyxl/style.py +303 -303
  94. pyxllib/stdlib/tablepyxl/tablepyxl.py +130 -130
  95. pyxllib/text/__init__.py +8 -8
  96. pyxllib/text/ahocorasick.py +39 -39
  97. pyxllib/text/airscript.js +744 -0
  98. pyxllib/text/charclasslib.py +121 -109
  99. pyxllib/text/jiebalib.py +267 -264
  100. pyxllib/text/jinjalib.py +32 -0
  101. pyxllib/text/jsa_ai_prompt.md +271 -0
  102. pyxllib/text/jscode.py +922 -767
  103. pyxllib/text/latex/__init__.py +158 -158
  104. pyxllib/text/levenshtein.py +303 -303
  105. pyxllib/text/nestenv.py +1215 -1215
  106. pyxllib/text/newbie.py +300 -288
  107. pyxllib/text/pupil/__init__.py +8 -8
  108. pyxllib/text/pupil/common.py +1121 -1095
  109. pyxllib/text/pupil/xlalign.py +326 -326
  110. pyxllib/text/pycode.py +47 -47
  111. pyxllib/text/specialist/__init__.py +8 -8
  112. pyxllib/text/specialist/common.py +112 -112
  113. pyxllib/text/specialist/ptag.py +186 -186
  114. pyxllib/text/spellchecker.py +172 -172
  115. pyxllib/text/templates/echart_base.html +11 -0
  116. pyxllib/text/templates/highlight_code.html +17 -0
  117. pyxllib/text/templates/latex_editor.html +103 -0
  118. pyxllib/text/vbacode.py +17 -17
  119. pyxllib/text/xmllib.py +747 -685
  120. pyxllib/xl.py +42 -38
  121. pyxllib/xlcv.py +17 -17
  122. pyxllib-0.3.200.dist-info/METADATA +48 -0
  123. pyxllib-0.3.200.dist-info/RECORD +126 -0
  124. {pyxllib-0.3.96.dist-info → pyxllib-0.3.200.dist-info}/WHEEL +1 -2
  125. {pyxllib-0.3.96.dist-info → pyxllib-0.3.200.dist-info/licenses}/LICENSE +190 -190
  126. pyxllib/ext/autogui/__init__.py +0 -8
  127. pyxllib-0.3.96.dist-info/METADATA +0 -51
  128. pyxllib-0.3.96.dist-info/RECORD +0 -333
  129. pyxllib-0.3.96.dist-info/top_level.txt +0 -2
  130. pyxlpr/ai/__init__.py +0 -5
  131. pyxlpr/ai/clientlib.py +0 -1281
  132. pyxlpr/ai/specialist.py +0 -286
  133. pyxlpr/ai/torch_app.py +0 -172
  134. pyxlpr/ai/xlpaddle.py +0 -655
  135. pyxlpr/ai/xltorch.py +0 -705
  136. pyxlpr/data/__init__.py +0 -11
  137. pyxlpr/data/coco.py +0 -1325
  138. pyxlpr/data/datacls.py +0 -365
  139. pyxlpr/data/datasets.py +0 -200
  140. pyxlpr/data/gptlib.py +0 -1291
  141. pyxlpr/data/icdar/__init__.py +0 -96
  142. pyxlpr/data/icdar/deteval.py +0 -377
  143. pyxlpr/data/icdar/icdar2013.py +0 -341
  144. pyxlpr/data/icdar/iou.py +0 -340
  145. pyxlpr/data/icdar/rrc_evaluation_funcs_1_1.py +0 -463
  146. pyxlpr/data/imtextline.py +0 -473
  147. pyxlpr/data/labelme.py +0 -866
  148. pyxlpr/data/removeline.py +0 -179
  149. pyxlpr/data/specialist.py +0 -57
  150. pyxlpr/eval/__init__.py +0 -85
  151. pyxlpr/paddleocr.py +0 -776
  152. pyxlpr/ppocr/__init__.py +0 -15
  153. pyxlpr/ppocr/configs/rec/multi_language/generate_multi_language_configs.py +0 -226
  154. pyxlpr/ppocr/data/__init__.py +0 -135
  155. pyxlpr/ppocr/data/imaug/ColorJitter.py +0 -26
  156. pyxlpr/ppocr/data/imaug/__init__.py +0 -67
  157. pyxlpr/ppocr/data/imaug/copy_paste.py +0 -170
  158. pyxlpr/ppocr/data/imaug/east_process.py +0 -437
  159. pyxlpr/ppocr/data/imaug/gen_table_mask.py +0 -244
  160. pyxlpr/ppocr/data/imaug/iaa_augment.py +0 -114
  161. pyxlpr/ppocr/data/imaug/label_ops.py +0 -789
  162. pyxlpr/ppocr/data/imaug/make_border_map.py +0 -184
  163. pyxlpr/ppocr/data/imaug/make_pse_gt.py +0 -106
  164. pyxlpr/ppocr/data/imaug/make_shrink_map.py +0 -126
  165. pyxlpr/ppocr/data/imaug/operators.py +0 -433
  166. pyxlpr/ppocr/data/imaug/pg_process.py +0 -906
  167. pyxlpr/ppocr/data/imaug/randaugment.py +0 -143
  168. pyxlpr/ppocr/data/imaug/random_crop_data.py +0 -239
  169. pyxlpr/ppocr/data/imaug/rec_img_aug.py +0 -533
  170. pyxlpr/ppocr/data/imaug/sast_process.py +0 -777
  171. pyxlpr/ppocr/data/imaug/text_image_aug/__init__.py +0 -17
  172. pyxlpr/ppocr/data/imaug/text_image_aug/augment.py +0 -120
  173. pyxlpr/ppocr/data/imaug/text_image_aug/warp_mls.py +0 -168
  174. pyxlpr/ppocr/data/lmdb_dataset.py +0 -115
  175. pyxlpr/ppocr/data/pgnet_dataset.py +0 -104
  176. pyxlpr/ppocr/data/pubtab_dataset.py +0 -107
  177. pyxlpr/ppocr/data/simple_dataset.py +0 -372
  178. pyxlpr/ppocr/losses/__init__.py +0 -61
  179. pyxlpr/ppocr/losses/ace_loss.py +0 -52
  180. pyxlpr/ppocr/losses/basic_loss.py +0 -135
  181. pyxlpr/ppocr/losses/center_loss.py +0 -88
  182. pyxlpr/ppocr/losses/cls_loss.py +0 -30
  183. pyxlpr/ppocr/losses/combined_loss.py +0 -67
  184. pyxlpr/ppocr/losses/det_basic_loss.py +0 -208
  185. pyxlpr/ppocr/losses/det_db_loss.py +0 -80
  186. pyxlpr/ppocr/losses/det_east_loss.py +0 -63
  187. pyxlpr/ppocr/losses/det_pse_loss.py +0 -149
  188. pyxlpr/ppocr/losses/det_sast_loss.py +0 -121
  189. pyxlpr/ppocr/losses/distillation_loss.py +0 -272
  190. pyxlpr/ppocr/losses/e2e_pg_loss.py +0 -140
  191. pyxlpr/ppocr/losses/kie_sdmgr_loss.py +0 -113
  192. pyxlpr/ppocr/losses/rec_aster_loss.py +0 -99
  193. pyxlpr/ppocr/losses/rec_att_loss.py +0 -39
  194. pyxlpr/ppocr/losses/rec_ctc_loss.py +0 -44
  195. pyxlpr/ppocr/losses/rec_enhanced_ctc_loss.py +0 -70
  196. pyxlpr/ppocr/losses/rec_nrtr_loss.py +0 -30
  197. pyxlpr/ppocr/losses/rec_sar_loss.py +0 -28
  198. pyxlpr/ppocr/losses/rec_srn_loss.py +0 -47
  199. pyxlpr/ppocr/losses/table_att_loss.py +0 -109
  200. pyxlpr/ppocr/metrics/__init__.py +0 -44
  201. pyxlpr/ppocr/metrics/cls_metric.py +0 -45
  202. pyxlpr/ppocr/metrics/det_metric.py +0 -82
  203. pyxlpr/ppocr/metrics/distillation_metric.py +0 -73
  204. pyxlpr/ppocr/metrics/e2e_metric.py +0 -86
  205. pyxlpr/ppocr/metrics/eval_det_iou.py +0 -274
  206. pyxlpr/ppocr/metrics/kie_metric.py +0 -70
  207. pyxlpr/ppocr/metrics/rec_metric.py +0 -75
  208. pyxlpr/ppocr/metrics/table_metric.py +0 -50
  209. pyxlpr/ppocr/modeling/architectures/__init__.py +0 -32
  210. pyxlpr/ppocr/modeling/architectures/base_model.py +0 -88
  211. pyxlpr/ppocr/modeling/architectures/distillation_model.py +0 -60
  212. pyxlpr/ppocr/modeling/backbones/__init__.py +0 -54
  213. pyxlpr/ppocr/modeling/backbones/det_mobilenet_v3.py +0 -268
  214. pyxlpr/ppocr/modeling/backbones/det_resnet_vd.py +0 -246
  215. pyxlpr/ppocr/modeling/backbones/det_resnet_vd_sast.py +0 -285
  216. pyxlpr/ppocr/modeling/backbones/e2e_resnet_vd_pg.py +0 -265
  217. pyxlpr/ppocr/modeling/backbones/kie_unet_sdmgr.py +0 -186
  218. pyxlpr/ppocr/modeling/backbones/rec_mobilenet_v3.py +0 -138
  219. pyxlpr/ppocr/modeling/backbones/rec_mv1_enhance.py +0 -258
  220. pyxlpr/ppocr/modeling/backbones/rec_nrtr_mtb.py +0 -48
  221. pyxlpr/ppocr/modeling/backbones/rec_resnet_31.py +0 -210
  222. pyxlpr/ppocr/modeling/backbones/rec_resnet_aster.py +0 -143
  223. pyxlpr/ppocr/modeling/backbones/rec_resnet_fpn.py +0 -307
  224. pyxlpr/ppocr/modeling/backbones/rec_resnet_vd.py +0 -286
  225. pyxlpr/ppocr/modeling/heads/__init__.py +0 -54
  226. pyxlpr/ppocr/modeling/heads/cls_head.py +0 -52
  227. pyxlpr/ppocr/modeling/heads/det_db_head.py +0 -118
  228. pyxlpr/ppocr/modeling/heads/det_east_head.py +0 -121
  229. pyxlpr/ppocr/modeling/heads/det_pse_head.py +0 -37
  230. pyxlpr/ppocr/modeling/heads/det_sast_head.py +0 -128
  231. pyxlpr/ppocr/modeling/heads/e2e_pg_head.py +0 -253
  232. pyxlpr/ppocr/modeling/heads/kie_sdmgr_head.py +0 -206
  233. pyxlpr/ppocr/modeling/heads/multiheadAttention.py +0 -163
  234. pyxlpr/ppocr/modeling/heads/rec_aster_head.py +0 -393
  235. pyxlpr/ppocr/modeling/heads/rec_att_head.py +0 -202
  236. pyxlpr/ppocr/modeling/heads/rec_ctc_head.py +0 -88
  237. pyxlpr/ppocr/modeling/heads/rec_nrtr_head.py +0 -826
  238. pyxlpr/ppocr/modeling/heads/rec_sar_head.py +0 -402
  239. pyxlpr/ppocr/modeling/heads/rec_srn_head.py +0 -280
  240. pyxlpr/ppocr/modeling/heads/self_attention.py +0 -406
  241. pyxlpr/ppocr/modeling/heads/table_att_head.py +0 -246
  242. pyxlpr/ppocr/modeling/necks/__init__.py +0 -32
  243. pyxlpr/ppocr/modeling/necks/db_fpn.py +0 -111
  244. pyxlpr/ppocr/modeling/necks/east_fpn.py +0 -188
  245. pyxlpr/ppocr/modeling/necks/fpn.py +0 -138
  246. pyxlpr/ppocr/modeling/necks/pg_fpn.py +0 -314
  247. pyxlpr/ppocr/modeling/necks/rnn.py +0 -92
  248. pyxlpr/ppocr/modeling/necks/sast_fpn.py +0 -284
  249. pyxlpr/ppocr/modeling/necks/table_fpn.py +0 -110
  250. pyxlpr/ppocr/modeling/transforms/__init__.py +0 -28
  251. pyxlpr/ppocr/modeling/transforms/stn.py +0 -135
  252. pyxlpr/ppocr/modeling/transforms/tps.py +0 -308
  253. pyxlpr/ppocr/modeling/transforms/tps_spatial_transformer.py +0 -156
  254. pyxlpr/ppocr/optimizer/__init__.py +0 -61
  255. pyxlpr/ppocr/optimizer/learning_rate.py +0 -228
  256. pyxlpr/ppocr/optimizer/lr_scheduler.py +0 -49
  257. pyxlpr/ppocr/optimizer/optimizer.py +0 -160
  258. pyxlpr/ppocr/optimizer/regularizer.py +0 -52
  259. pyxlpr/ppocr/postprocess/__init__.py +0 -55
  260. pyxlpr/ppocr/postprocess/cls_postprocess.py +0 -33
  261. pyxlpr/ppocr/postprocess/db_postprocess.py +0 -234
  262. pyxlpr/ppocr/postprocess/east_postprocess.py +0 -143
  263. pyxlpr/ppocr/postprocess/locality_aware_nms.py +0 -200
  264. pyxlpr/ppocr/postprocess/pg_postprocess.py +0 -52
  265. pyxlpr/ppocr/postprocess/pse_postprocess/__init__.py +0 -15
  266. pyxlpr/ppocr/postprocess/pse_postprocess/pse/__init__.py +0 -29
  267. pyxlpr/ppocr/postprocess/pse_postprocess/pse/setup.py +0 -14
  268. pyxlpr/ppocr/postprocess/pse_postprocess/pse_postprocess.py +0 -118
  269. pyxlpr/ppocr/postprocess/rec_postprocess.py +0 -654
  270. pyxlpr/ppocr/postprocess/sast_postprocess.py +0 -355
  271. pyxlpr/ppocr/tools/__init__.py +0 -14
  272. pyxlpr/ppocr/tools/eval.py +0 -83
  273. pyxlpr/ppocr/tools/export_center.py +0 -77
  274. pyxlpr/ppocr/tools/export_model.py +0 -129
  275. pyxlpr/ppocr/tools/infer/predict_cls.py +0 -151
  276. pyxlpr/ppocr/tools/infer/predict_det.py +0 -300
  277. pyxlpr/ppocr/tools/infer/predict_e2e.py +0 -169
  278. pyxlpr/ppocr/tools/infer/predict_rec.py +0 -414
  279. pyxlpr/ppocr/tools/infer/predict_system.py +0 -204
  280. pyxlpr/ppocr/tools/infer/utility.py +0 -629
  281. pyxlpr/ppocr/tools/infer_cls.py +0 -83
  282. pyxlpr/ppocr/tools/infer_det.py +0 -134
  283. pyxlpr/ppocr/tools/infer_e2e.py +0 -122
  284. pyxlpr/ppocr/tools/infer_kie.py +0 -153
  285. pyxlpr/ppocr/tools/infer_rec.py +0 -146
  286. pyxlpr/ppocr/tools/infer_table.py +0 -107
  287. pyxlpr/ppocr/tools/program.py +0 -596
  288. pyxlpr/ppocr/tools/test_hubserving.py +0 -117
  289. pyxlpr/ppocr/tools/train.py +0 -163
  290. pyxlpr/ppocr/tools/xlprog.py +0 -748
  291. pyxlpr/ppocr/utils/EN_symbol_dict.txt +0 -94
  292. pyxlpr/ppocr/utils/__init__.py +0 -24
  293. pyxlpr/ppocr/utils/dict/ar_dict.txt +0 -117
  294. pyxlpr/ppocr/utils/dict/arabic_dict.txt +0 -162
  295. pyxlpr/ppocr/utils/dict/be_dict.txt +0 -145
  296. pyxlpr/ppocr/utils/dict/bg_dict.txt +0 -140
  297. pyxlpr/ppocr/utils/dict/chinese_cht_dict.txt +0 -8421
  298. pyxlpr/ppocr/utils/dict/cyrillic_dict.txt +0 -163
  299. pyxlpr/ppocr/utils/dict/devanagari_dict.txt +0 -167
  300. pyxlpr/ppocr/utils/dict/en_dict.txt +0 -63
  301. pyxlpr/ppocr/utils/dict/fa_dict.txt +0 -136
  302. pyxlpr/ppocr/utils/dict/french_dict.txt +0 -136
  303. pyxlpr/ppocr/utils/dict/german_dict.txt +0 -143
  304. pyxlpr/ppocr/utils/dict/hi_dict.txt +0 -162
  305. pyxlpr/ppocr/utils/dict/it_dict.txt +0 -118
  306. pyxlpr/ppocr/utils/dict/japan_dict.txt +0 -4399
  307. pyxlpr/ppocr/utils/dict/ka_dict.txt +0 -153
  308. pyxlpr/ppocr/utils/dict/korean_dict.txt +0 -3688
  309. pyxlpr/ppocr/utils/dict/latin_dict.txt +0 -185
  310. pyxlpr/ppocr/utils/dict/mr_dict.txt +0 -153
  311. pyxlpr/ppocr/utils/dict/ne_dict.txt +0 -153
  312. pyxlpr/ppocr/utils/dict/oc_dict.txt +0 -96
  313. pyxlpr/ppocr/utils/dict/pu_dict.txt +0 -130
  314. pyxlpr/ppocr/utils/dict/rs_dict.txt +0 -91
  315. pyxlpr/ppocr/utils/dict/rsc_dict.txt +0 -134
  316. pyxlpr/ppocr/utils/dict/ru_dict.txt +0 -125
  317. pyxlpr/ppocr/utils/dict/ta_dict.txt +0 -128
  318. pyxlpr/ppocr/utils/dict/table_dict.txt +0 -277
  319. pyxlpr/ppocr/utils/dict/table_structure_dict.txt +0 -2759
  320. pyxlpr/ppocr/utils/dict/te_dict.txt +0 -151
  321. pyxlpr/ppocr/utils/dict/ug_dict.txt +0 -114
  322. pyxlpr/ppocr/utils/dict/uk_dict.txt +0 -142
  323. pyxlpr/ppocr/utils/dict/ur_dict.txt +0 -137
  324. pyxlpr/ppocr/utils/dict/xi_dict.txt +0 -110
  325. pyxlpr/ppocr/utils/dict90.txt +0 -90
  326. pyxlpr/ppocr/utils/e2e_metric/Deteval.py +0 -574
  327. pyxlpr/ppocr/utils/e2e_metric/polygon_fast.py +0 -83
  328. pyxlpr/ppocr/utils/e2e_utils/extract_batchsize.py +0 -87
  329. pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_fast.py +0 -457
  330. pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_slow.py +0 -592
  331. pyxlpr/ppocr/utils/e2e_utils/pgnet_pp_utils.py +0 -162
  332. pyxlpr/ppocr/utils/e2e_utils/visual.py +0 -162
  333. pyxlpr/ppocr/utils/en_dict.txt +0 -95
  334. pyxlpr/ppocr/utils/gen_label.py +0 -81
  335. pyxlpr/ppocr/utils/ic15_dict.txt +0 -36
  336. pyxlpr/ppocr/utils/iou.py +0 -54
  337. pyxlpr/ppocr/utils/logging.py +0 -69
  338. pyxlpr/ppocr/utils/network.py +0 -84
  339. pyxlpr/ppocr/utils/ppocr_keys_v1.txt +0 -6623
  340. pyxlpr/ppocr/utils/profiler.py +0 -110
  341. pyxlpr/ppocr/utils/save_load.py +0 -150
  342. pyxlpr/ppocr/utils/stats.py +0 -72
  343. pyxlpr/ppocr/utils/utility.py +0 -80
  344. pyxlpr/ppstructure/__init__.py +0 -13
  345. pyxlpr/ppstructure/predict_system.py +0 -187
  346. pyxlpr/ppstructure/table/__init__.py +0 -13
  347. pyxlpr/ppstructure/table/eval_table.py +0 -72
  348. pyxlpr/ppstructure/table/matcher.py +0 -192
  349. pyxlpr/ppstructure/table/predict_structure.py +0 -136
  350. pyxlpr/ppstructure/table/predict_table.py +0 -221
  351. pyxlpr/ppstructure/table/table_metric/__init__.py +0 -16
  352. pyxlpr/ppstructure/table/table_metric/parallel.py +0 -51
  353. pyxlpr/ppstructure/table/table_metric/table_metric.py +0 -247
  354. pyxlpr/ppstructure/table/tablepyxl/__init__.py +0 -13
  355. pyxlpr/ppstructure/table/tablepyxl/style.py +0 -283
  356. pyxlpr/ppstructure/table/tablepyxl/tablepyxl.py +0 -118
  357. pyxlpr/ppstructure/utility.py +0 -71
  358. pyxlpr/xlai.py +0 -10
@@ -1,200 +1,203 @@
1
- #!/usr/bin/env python3
2
- # -*- coding: utf-8 -*-
3
- # @Author : 陈坤泽
4
- # @Email : 877362867@qq.com
5
- # @Date : 2020/06/01 18:13
6
-
7
- import copy
8
-
9
- from pyxllib.prog.pupil import dprint, prettifystr
10
- from pyxllib.prog.specialist.browser import Explorer
11
- from pyxllib.algo.pupil import intersection_split
12
- from pyxllib.file.specialist import File, Dir, filesmatch, get_encoding, XlPath
13
-
14
-
15
- # 需要使用的第三方软件
16
- # BCompare.exe, bcompare函数要用
17
-
18
- class BCompare(Explorer):
19
- def __init__(self, app='BCompare', shell=False):
20
- super().__init__(app, shell)
21
-
22
- @classmethod
23
- def to_bcompare_files(cls, *args, files=None):
24
- """ 这个需要一次性获得所有的数据,才适合分析整体上要怎么获取对应的多个文件
25
-
26
- :param files: 每个arg对应的文件名,默认按 'left'、'right', 'base' 来生成
27
- 也可以输入一个list[str],表示多个args依次对应的文件名
28
- filename的长度可以跟args不一致,多的不用,少的自动生成
29
- """
30
- # 1 如果oldfile和newfile都是dict、set、list、tuple,则使用特殊方法文本化
31
- # 如果两个都是list,不应该提取key后比较,所以限制第1个类型必须是dict或set,然后第二个类型可以适当放宽条件
32
- # if not oldfile: oldfile = str(oldfile)
33
- if len(args) > 1 and isinstance(args[0], (dict, set)) and isinstance(args[1], (dict, set, list, tuple)):
34
- args = copy.copy(list(args))
35
- t = [prettifystr(li) for li in intersection_split(args[0], args[1])]
36
- args[0] = f'【共有部分】,{t[0]}\n\n【独有部分】,{t[1]}'
37
- args[1] = f'【共有部分】,{t[2]}\n\n【独有部分】,{t[3]}'
38
-
39
- # 2 参数对齐
40
- if not isinstance(files, (list, tuple)):
41
- files = [files]
42
- if len(files) < len(args):
43
- files += [None] * (len(args) - len(files))
44
- ref_names = ['left', 'right', 'base']
45
-
46
- # 3 将每个参数转成一个文件
47
- new_args = []
48
- default_suffix = None
49
- for i, arg in enumerate(args):
50
- f = XlPath.safe_init(arg)
51
- if f.is_file(): # 是文件对象,且存在
52
- new_args.append(f)
53
- if not default_suffix:
54
- default_suffix = f.suffix
55
- # elif isinstance(f, File): # 文本内容也可能生成合法的伪路径,既然找不到还是统一按字符串对比差异好
56
- # # 是文件对象,但不存在 -> 报错
57
- # raise FileNotFoundError(f'{f}')
58
- else: # 不是文件对象,要转存到文件
59
- if not files[i]: # 没有设置文件名则生成一个
60
- files[i] = XlPath.init(ref_names[i], XlPath.tempdir(), suffix=default_suffix)
61
- else:
62
- files[i] = XlPath(files[i])
63
- files[i].write_text(str(arg))
64
- new_args.append(files[i])
65
-
66
- return new_args
67
-
68
- def __call__(self, *args, wait=True, files=None, sameoff=False, **kwargs):
69
- r"""
70
- :param wait:
71
- 一般调用bcompare的时候,默认值wait=True,python是打开一个子进程并等待bcompare软件关闭后,才继续执行后续代码。
72
- 如果你的业务场景并不需要等待bcompare关闭后执行后续python代码,可以设为wait=False,不等待。
73
- :param sameoff: 如果设为True,则会判断内容,两份内容如果相同则不打开bc
74
- 这个参数一定程度会影响性能,非必要的时候不要开。
75
- 或者在外部的时候,更清楚数据情况,可以在外部判断内容不重复再跑bcompare函数
76
- 这个目前的实现策略,是读取文件重新判断的,会有性能开销,默认关闭该功能
77
- :return: 程序返回被修改的oldfile内容
78
- 注意如果没有修改,或者wait=False,会返回原始值
79
- """
80
- files = self.to_bcompare_files(*args, files=files)
81
-
82
- if sameoff and len(files) > 1:
83
- if files[0].read_auto() == files[1].read_auto():
84
- return
85
- super().__call__(*([str(f) for f in files]), wait=wait, **kwargs)
86
- # bc软件操作中可能会修改原文内容,所以这里需要重新读取,不能用前面算过的结果
87
- return XlPath(files[0]).read_auto()
88
-
89
-
90
- bcompare = BCompare() # nowatch: 调试阶段,不需要自动watch的变量
91
-
92
-
93
- def modify_file(file, func, *, outfile=None, file_mode=None, debug=0):
94
- """ 对单个文件就行优化的功能函数
95
-
96
- 这样一些底层函数功能可以写成数据级的接口,然后由这个函数负责文件的读写操作,并且支持debug比较前后内容差异
97
-
98
- :param outfile: 默认是对file原地操作,如果使用该参数,则将处理后的内容写入outfile文件
99
- :param file_mode: 指定文件读取类型格式,例如'.json'是json文件,读取为字典
100
- :param debug: 这个功能可以对照refine分级轮理解
101
- outfile参数时,原地操作
102
- 0,【直接原地操作】关闭调试,直接运行 (根据outfile=None选择原地操作,或者指定生成新文件)
103
- 1,【进行审核】打开BC比较差异,左边原始内容,右边参考内容 (打开前后差异内容对比)
104
- -1,【先斩后奏】介于完全不调试和全部人工检查之间,特殊的差异比较。左边放原始文件修改后的结果,右边对照原内容。
105
- outfile参数时
106
- 0 | False,直接生成目标文件,如果outfile已存在会被覆盖
107
- 1 | True,直接生成目标文件,但是会弹出bc比较前后内容差异 (相同内容不会弹出)
108
- """
109
- infile = File(file)
110
- enc = get_encoding(infile.read(mode='b'))
111
- data = infile.read(mode=file_mode, encoding=enc)
112
- origin_content = str(data)
113
- new_data = func(data)
114
-
115
- isdiff = origin_content != str(new_data)
116
- if outfile is None: # 原地操作
117
- if isdiff: # 内容不同才会有相关debug功能,否则静默跳过就好
118
- if debug == 0:
119
- infile.write(new_data, mode=file_mode) # 直接处理
120
- elif debug == 1:
121
- temp_file = File('refine_content', Dir.TEMP, suffix=infile.suffix).write(new_data)
122
- bcompare(infile, temp_file) # 使用beyond compare软件打开对比查看
123
- elif debug == -1:
124
- temp_file = File('origin_content', Dir.TEMP, suffix=infile.suffix)
125
- infile.copy(temp_file)
126
- infile.write(new_data, mode=file_mode, encoding=enc) # 把原文件内容替换了
127
- bcompare(infile, temp_file) # 然后显示与旧内容进行对比
128
- else:
129
- raise ValueError(f'{debug}')
130
- else:
131
- outfile = File(outfile)
132
- outfile.write(new_data, mode=file_mode, encoding=enc) # 直接处理
133
- if debug and isdiff:
134
- bcompare(infile, outfile)
135
-
136
- return isdiff
137
-
138
-
139
- class PairContent:
140
- """ 配对文本类,主要用于bc差异比较 """
141
-
142
- def __init__(self, left_file_name=None, right_file_name=None):
143
- self.left_file = File(left_file_name) if left_file_name else left_file_name
144
- self.right_file = File(right_file_name) if right_file_name else right_file_name
145
- self.left, self.right = [], []
146
-
147
- def add(self, lt, rt=None):
148
- """ rt不加,默认本轮内容是同lt """
149
- lt = str(lt)
150
- self.left.append(lt)
151
- rt = lt if rt is None else str(rt)
152
- self.right.append(rt)
153
-
154
- def bcompare(self, **kwargs):
155
- left, right = '\n'.join(self.left), '\n'.join(self.right)
156
- if self.left_file is not None:
157
- left = self.left_file.write(left)
158
- if self.right_file is not None:
159
- right = self.right_file.write(right)
160
- bcompare(left, right, **kwargs)
161
-
162
-
163
- def filetext_replace(files, func, *,
164
- count=-1, start=1, bc=False, write=False, if_exists=None):
165
- r"""遍历目录下的文本文件进行批量处理的功能函数
166
-
167
- :param files: 文件匹配规则,详见filesmatch用法
168
- :param func: 通用文本处理函数
169
- :param count: 匹配到count个文件后结束,防止满足条件的文件太多,程序会跑死
170
- :param start: 从编号几的文件开始查找,一般在遇到意外调试的时候使用
171
- :param bc: 使用beyond compare软件
172
- 注意bc的优先级比write高,如果bc和write同时为True,则会开bc,但并不会执行write
173
- :param write: 是否原地修改文件内容进行保存
174
- :param if_exists: 是否进行备份,详见writefile里的参数文件
175
- :return: 满足条件的文件清单
176
- """
177
- ls = []
178
- total = 0
179
- for f in filesmatch(files):
180
- # if 'A4-Exam' in f:
181
- # continue
182
- total += 1
183
- if total < start:
184
- continue
185
- s0 = File(f).read()
186
- s1 = func(s0)
187
- if s0 != s1:
188
- match = len(ls) + 1
189
- dprint(f, total, match)
190
- if bc:
191
- bcompare(f, s1)
192
- elif write: # 如果开了bc,程序是绝对不会自动写入的
193
- File(f).write(s1, if_exists=if_exists)
194
- ls.append(f)
195
- if len(ls) == count:
196
- break
197
-
198
- match_num = len(ls)
199
- dprint(total, match_num)
200
- return ls
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ # @Author : 陈坤泽
4
+ # @Email : 877362867@qq.com
5
+ # @Date : 2020/06/01 18:13
6
+
7
+ import copy
8
+
9
+ from pyxllib.prog.pupil import dprint, prettifystr
10
+ from pyxllib.prog.specialist.browser import Explorer
11
+ from pyxllib.algo.pupil import intersection_split
12
+ from pyxllib.file.specialist import File, Dir, filesmatch, get_encoding, XlPath
13
+
14
+
15
+ # 需要使用的第三方软件
16
+ # BCompare.exe, bcompare函数要用
17
+
18
+ class BCompare(Explorer):
19
+ def __init__(self, app='bcomp', shell=False):
20
+ """
21
+ 240512周日20:06,本来写的是BCompare,但是友鑫mac电脑上发现似乎有问题,所以改成bcomp,这种在windows上也能用
22
+ """
23
+ super().__init__(app, shell)
24
+
25
+ @classmethod
26
+ def to_bcompare_files(cls, *args, files=None):
27
+ """ 这个需要一次性获得所有的数据,才适合分析整体上要怎么获取对应的多个文件
28
+
29
+ :param files: 每个arg对应的文件名,默认按 'left'、'right', 'base' 来生成
30
+ 也可以输入一个list[str],表示多个args依次对应的文件名
31
+ filename的长度可以跟args不一致,多的不用,少的自动生成
32
+ """
33
+ # 1 如果oldfile和newfile都是dictsetlisttuple,则使用特殊方法文本化
34
+ # 如果两个都是list,不应该提取key后比较,所以限制第1个类型必须是dict或set,然后第二个类型可以适当放宽条件
35
+ # if not oldfile: oldfile = str(oldfile)
36
+ if len(args) > 1 and isinstance(args[0], (dict, set)) and isinstance(args[1], (dict, set, list, tuple)):
37
+ args = copy.copy(list(args))
38
+ t = [prettifystr(li) for li in intersection_split(args[0], args[1])]
39
+ args[0] = f'【共有部分】,{t[0]}\n\n【独有部分】,{t[1]}'
40
+ args[1] = f'【共有部分】,{t[2]}\n\n【独有部分】,{t[3]}'
41
+
42
+ # 2 参数对齐
43
+ if not isinstance(files, (list, tuple)):
44
+ files = [files]
45
+ if len(files) < len(args):
46
+ files += [None] * (len(args) - len(files))
47
+ ref_names = ['left', 'right', 'base']
48
+
49
+ # 3 将每个参数转成一个文件
50
+ new_args = []
51
+ default_suffix = None
52
+ for i, arg in enumerate(args):
53
+ f = XlPath.safe_init(arg)
54
+ if f is not None and f.is_file(): # 是文件对象,且存在
55
+ new_args.append(f)
56
+ if not default_suffix:
57
+ default_suffix = f.suffix
58
+ # elif isinstance(f, File): # 文本内容也可能生成合法的伪路径,既然找不到还是统一按字符串对比差异好
59
+ # # 是文件对象,但不存在 -> 报错
60
+ # raise FileNotFoundError(f'{f}')
61
+ else: # 不是文件对象,要转存到文件
62
+ if not files[i]: # 没有设置文件名则生成一个
63
+ files[i] = XlPath.init(ref_names[i], XlPath.tempdir(), suffix=default_suffix)
64
+ else:
65
+ files[i] = XlPath(files[i])
66
+ files[i].write_text(str(arg))
67
+ new_args.append(files[i])
68
+
69
+ return new_args
70
+
71
+ def __call__(self, *args, wait=True, files=None, sameoff=False, **kwargs):
72
+ r"""
73
+ :param wait:
74
+ 一般调用bcompare的时候,默认值wait=True,python是打开一个子进程并等待bcompare软件关闭后,才继续执行后续代码。
75
+ 如果你的业务场景并不需要等待bcompare关闭后执行后续python代码,可以设为wait=False,不等待。
76
+ :param sameoff: 如果设为True,则会判断内容,两份内容如果相同则不打开bc
77
+ 这个参数一定程度会影响性能,非必要的时候不要开。
78
+ 或者在外部的时候,更清楚数据情况,可以在外部判断内容不重复再跑bcompare函数
79
+ 这个目前的实现策略,是读取文件重新判断的,会有性能开销,默认关闭该功能
80
+ :return: 程序返回被修改的oldfile内容
81
+ 注意如果没有修改,或者wait=False,会返回原始值
82
+ """
83
+ files = self.to_bcompare_files(*args, files=files)
84
+
85
+ if sameoff and len(files) > 1:
86
+ if files[0].read_auto() == files[1].read_auto():
87
+ return
88
+ super().__call__(*([str(f) for f in files]), wait=wait, **kwargs)
89
+ # bc软件操作中可能会修改原文内容,所以这里需要重新读取,不能用前面算过的结果
90
+ return XlPath(files[0]).read_auto()
91
+
92
+
93
+ bcompare = BCompare() # nowatch: 调试阶段,不需要自动watch的变量
94
+
95
+
96
+ def modify_file(file, func, *, outfile=None, file_mode=None, debug=0):
97
+ """ 对单个文件就行优化的功能函数
98
+
99
+ 这样一些底层函数功能可以写成数据级的接口,然后由这个函数负责文件的读写操作,并且支持debug比较前后内容差异
100
+
101
+ :param outfile: 默认是对file原地操作,如果使用该参数,则将处理后的内容写入outfile文件
102
+ :param file_mode: 指定文件读取类型格式,例如'.json'是json文件,读取为字典
103
+ :param debug: 这个功能可以对照refine分级轮理解
104
+ 无outfile参数时,原地操作
105
+ 0,【直接原地操作】关闭调试,直接运行 (根据outfile=None选择原地操作,或者指定生成新文件)
106
+ 1,【进行审核】打开BC比较差异,左边原始内容,右边参考内容 (打开前后差异内容对比)
107
+ -1,【先斩后奏】介于完全不调试和全部人工检查之间,特殊的差异比较。左边放原始文件修改后的结果,右边对照原内容。
108
+ 有outfile参数时
109
+ 0 | False,直接生成目标文件,如果outfile已存在会被覆盖
110
+ 1 | True,直接生成目标文件,但是会弹出bc比较前后内容差异 (相同内容不会弹出)
111
+ """
112
+ infile = File(file)
113
+ enc = get_encoding(infile.read(mode='b'))
114
+ data = infile.read(mode=file_mode, encoding=enc)
115
+ origin_content = str(data)
116
+ new_data = func(data)
117
+
118
+ isdiff = origin_content != str(new_data)
119
+ if outfile is None: # 原地操作
120
+ if isdiff: # 内容不同才会有相关debug功能,否则静默跳过就好
121
+ if debug == 0:
122
+ infile.write(new_data, mode=file_mode) # 直接处理
123
+ elif debug == 1:
124
+ temp_file = File('refine_content', Dir.TEMP, suffix=infile.suffix).write(new_data)
125
+ bcompare(infile, temp_file) # 使用beyond compare软件打开对比查看
126
+ elif debug == -1:
127
+ temp_file = File('origin_content', Dir.TEMP, suffix=infile.suffix)
128
+ infile.copy(temp_file)
129
+ infile.write(new_data, mode=file_mode, encoding=enc) # 把原文件内容替换了
130
+ bcompare(infile, temp_file) # 然后显示与旧内容进行对比
131
+ else:
132
+ raise ValueError(f'{debug}')
133
+ else:
134
+ outfile = File(outfile)
135
+ outfile.write(new_data, mode=file_mode, encoding=enc) # 直接处理
136
+ if debug and isdiff:
137
+ bcompare(infile, outfile)
138
+
139
+ return isdiff
140
+
141
+
142
+ class PairContent:
143
+ """ 配对文本类,主要用于bc差异比较 """
144
+
145
+ def __init__(self, left_file_name=None, right_file_name=None):
146
+ self.left_file = File(left_file_name) if left_file_name else left_file_name
147
+ self.right_file = File(right_file_name) if right_file_name else right_file_name
148
+ self.left, self.right = [], []
149
+
150
+ def add(self, lt, rt=None):
151
+ """ rt不加,默认本轮内容是同lt """
152
+ lt = str(lt)
153
+ self.left.append(lt)
154
+ rt = lt if rt is None else str(rt)
155
+ self.right.append(rt)
156
+
157
+ def bcompare(self, **kwargs):
158
+ left, right = '\n'.join(self.left), '\n'.join(self.right)
159
+ if self.left_file is not None:
160
+ left = self.left_file.write(left)
161
+ if self.right_file is not None:
162
+ right = self.right_file.write(right)
163
+ bcompare(left, right, **kwargs)
164
+
165
+
166
+ def filetext_replace(files, func, *,
167
+ count=-1, start=1, bc=False, write=False, if_exists=None):
168
+ r"""遍历目录下的文本文件进行批量处理的功能函数
169
+
170
+ :param files: 文件匹配规则,详见filesmatch用法
171
+ :param func: 通用文本处理函数
172
+ :param count: 匹配到count个文件后结束,防止满足条件的文件太多,程序会跑死
173
+ :param start: 从编号几的文件开始查找,一般在遇到意外调试的时候使用
174
+ :param bc: 使用beyond compare软件
175
+ 注意bc的优先级比write高,如果bc和write同时为True,则会开bc,但并不会执行write
176
+ :param write: 是否原地修改文件内容进行保存
177
+ :param if_exists: 是否进行备份,详见writefile里的参数文件
178
+ :return: 满足条件的文件清单
179
+ """
180
+ ls = []
181
+ total = 0
182
+ for f in filesmatch(files):
183
+ # if 'A4-Exam' in f:
184
+ # continue
185
+ total += 1
186
+ if total < start:
187
+ continue
188
+ s0 = File(f).read()
189
+ s1 = func(s0)
190
+ if s0 != s1:
191
+ match = len(ls) + 1
192
+ dprint(f, total, match)
193
+ if bc:
194
+ bcompare(f, s1)
195
+ elif write: # 如果开了bc,程序是绝对不会自动写入的
196
+ File(f).write(s1, if_exists=if_exists)
197
+ ls.append(f)
198
+ if len(ls) == count:
199
+ break
200
+
201
+ match_num = len(ls)
202
+ dprint(total, match_num)
203
+ return ls