pyxllib 0.3.96__py3-none-any.whl → 0.3.197__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 (306) hide show
  1. pyxllib/algo/geo.py +12 -0
  2. pyxllib/algo/intervals.py +1 -1
  3. pyxllib/algo/matcher.py +78 -0
  4. pyxllib/algo/pupil.py +187 -19
  5. pyxllib/algo/specialist.py +2 -1
  6. pyxllib/algo/stat.py +38 -2
  7. {pyxlpr → pyxllib/autogui}/__init__.py +1 -1
  8. pyxllib/autogui/activewin.py +246 -0
  9. pyxllib/autogui/all.py +9 -0
  10. pyxllib/{ext/autogui → autogui}/autogui.py +40 -11
  11. pyxllib/autogui/uiautolib.py +362 -0
  12. pyxllib/autogui/wechat.py +827 -0
  13. pyxllib/autogui/wechat_msg.py +421 -0
  14. pyxllib/autogui/wxautolib.py +84 -0
  15. pyxllib/cv/slidercaptcha.py +137 -0
  16. pyxllib/data/echarts.py +123 -12
  17. pyxllib/data/jsonlib.py +89 -0
  18. pyxllib/data/pglib.py +514 -30
  19. pyxllib/data/sqlite.py +231 -4
  20. pyxllib/ext/JLineViewer.py +14 -1
  21. pyxllib/ext/drissionlib.py +277 -0
  22. pyxllib/ext/kq5034lib.py +0 -1594
  23. pyxllib/ext/robustprocfile.py +497 -0
  24. pyxllib/ext/unixlib.py +6 -5
  25. pyxllib/ext/utools.py +108 -95
  26. pyxllib/ext/webhook.py +32 -14
  27. pyxllib/ext/wjxlib.py +88 -0
  28. pyxllib/ext/wpsapi.py +124 -0
  29. pyxllib/ext/xlwork.py +9 -0
  30. pyxllib/ext/yuquelib.py +1003 -71
  31. pyxllib/file/docxlib.py +1 -1
  32. pyxllib/file/libreoffice.py +165 -0
  33. pyxllib/file/movielib.py +9 -0
  34. pyxllib/file/packlib/__init__.py +112 -75
  35. pyxllib/file/pdflib.py +1 -1
  36. pyxllib/file/pupil.py +1 -1
  37. pyxllib/file/specialist/dirlib.py +1 -1
  38. pyxllib/file/specialist/download.py +10 -3
  39. pyxllib/file/specialist/filelib.py +266 -55
  40. pyxllib/file/xlsxlib.py +205 -50
  41. pyxllib/file/xlsyncfile.py +341 -0
  42. pyxllib/prog/cachetools.py +64 -0
  43. pyxllib/prog/filelock.py +42 -0
  44. pyxllib/prog/multiprogs.py +940 -0
  45. pyxllib/prog/newbie.py +9 -2
  46. pyxllib/prog/pupil.py +129 -60
  47. pyxllib/prog/specialist/__init__.py +176 -2
  48. pyxllib/prog/specialist/bc.py +5 -2
  49. pyxllib/prog/specialist/browser.py +11 -2
  50. pyxllib/prog/specialist/datetime.py +68 -0
  51. pyxllib/prog/specialist/tictoc.py +12 -13
  52. pyxllib/prog/specialist/xllog.py +5 -5
  53. pyxllib/prog/xlosenv.py +7 -0
  54. pyxllib/text/airscript.js +744 -0
  55. pyxllib/text/charclasslib.py +17 -5
  56. pyxllib/text/jiebalib.py +6 -3
  57. pyxllib/text/jinjalib.py +32 -0
  58. pyxllib/text/jsa_ai_prompt.md +271 -0
  59. pyxllib/text/jscode.py +159 -4
  60. pyxllib/text/nestenv.py +1 -1
  61. pyxllib/text/newbie.py +12 -0
  62. pyxllib/text/pupil/common.py +26 -0
  63. pyxllib/text/specialist/ptag.py +2 -2
  64. pyxllib/text/templates/echart_base.html +11 -0
  65. pyxllib/text/templates/highlight_code.html +17 -0
  66. pyxllib/text/templates/latex_editor.html +103 -0
  67. pyxllib/text/xmllib.py +76 -14
  68. pyxllib/xl.py +2 -1
  69. pyxllib-0.3.197.dist-info/METADATA +48 -0
  70. pyxllib-0.3.197.dist-info/RECORD +126 -0
  71. {pyxllib-0.3.96.dist-info → pyxllib-0.3.197.dist-info}/WHEEL +1 -2
  72. pyxllib/ext/autogui/__init__.py +0 -8
  73. pyxllib-0.3.96.dist-info/METADATA +0 -51
  74. pyxllib-0.3.96.dist-info/RECORD +0 -333
  75. pyxllib-0.3.96.dist-info/top_level.txt +0 -2
  76. pyxlpr/ai/__init__.py +0 -5
  77. pyxlpr/ai/clientlib.py +0 -1281
  78. pyxlpr/ai/specialist.py +0 -286
  79. pyxlpr/ai/torch_app.py +0 -172
  80. pyxlpr/ai/xlpaddle.py +0 -655
  81. pyxlpr/ai/xltorch.py +0 -705
  82. pyxlpr/data/__init__.py +0 -11
  83. pyxlpr/data/coco.py +0 -1325
  84. pyxlpr/data/datacls.py +0 -365
  85. pyxlpr/data/datasets.py +0 -200
  86. pyxlpr/data/gptlib.py +0 -1291
  87. pyxlpr/data/icdar/__init__.py +0 -96
  88. pyxlpr/data/icdar/deteval.py +0 -377
  89. pyxlpr/data/icdar/icdar2013.py +0 -341
  90. pyxlpr/data/icdar/iou.py +0 -340
  91. pyxlpr/data/icdar/rrc_evaluation_funcs_1_1.py +0 -463
  92. pyxlpr/data/imtextline.py +0 -473
  93. pyxlpr/data/labelme.py +0 -866
  94. pyxlpr/data/removeline.py +0 -179
  95. pyxlpr/data/specialist.py +0 -57
  96. pyxlpr/eval/__init__.py +0 -85
  97. pyxlpr/paddleocr.py +0 -776
  98. pyxlpr/ppocr/__init__.py +0 -15
  99. pyxlpr/ppocr/configs/rec/multi_language/generate_multi_language_configs.py +0 -226
  100. pyxlpr/ppocr/data/__init__.py +0 -135
  101. pyxlpr/ppocr/data/imaug/ColorJitter.py +0 -26
  102. pyxlpr/ppocr/data/imaug/__init__.py +0 -67
  103. pyxlpr/ppocr/data/imaug/copy_paste.py +0 -170
  104. pyxlpr/ppocr/data/imaug/east_process.py +0 -437
  105. pyxlpr/ppocr/data/imaug/gen_table_mask.py +0 -244
  106. pyxlpr/ppocr/data/imaug/iaa_augment.py +0 -114
  107. pyxlpr/ppocr/data/imaug/label_ops.py +0 -789
  108. pyxlpr/ppocr/data/imaug/make_border_map.py +0 -184
  109. pyxlpr/ppocr/data/imaug/make_pse_gt.py +0 -106
  110. pyxlpr/ppocr/data/imaug/make_shrink_map.py +0 -126
  111. pyxlpr/ppocr/data/imaug/operators.py +0 -433
  112. pyxlpr/ppocr/data/imaug/pg_process.py +0 -906
  113. pyxlpr/ppocr/data/imaug/randaugment.py +0 -143
  114. pyxlpr/ppocr/data/imaug/random_crop_data.py +0 -239
  115. pyxlpr/ppocr/data/imaug/rec_img_aug.py +0 -533
  116. pyxlpr/ppocr/data/imaug/sast_process.py +0 -777
  117. pyxlpr/ppocr/data/imaug/text_image_aug/__init__.py +0 -17
  118. pyxlpr/ppocr/data/imaug/text_image_aug/augment.py +0 -120
  119. pyxlpr/ppocr/data/imaug/text_image_aug/warp_mls.py +0 -168
  120. pyxlpr/ppocr/data/lmdb_dataset.py +0 -115
  121. pyxlpr/ppocr/data/pgnet_dataset.py +0 -104
  122. pyxlpr/ppocr/data/pubtab_dataset.py +0 -107
  123. pyxlpr/ppocr/data/simple_dataset.py +0 -372
  124. pyxlpr/ppocr/losses/__init__.py +0 -61
  125. pyxlpr/ppocr/losses/ace_loss.py +0 -52
  126. pyxlpr/ppocr/losses/basic_loss.py +0 -135
  127. pyxlpr/ppocr/losses/center_loss.py +0 -88
  128. pyxlpr/ppocr/losses/cls_loss.py +0 -30
  129. pyxlpr/ppocr/losses/combined_loss.py +0 -67
  130. pyxlpr/ppocr/losses/det_basic_loss.py +0 -208
  131. pyxlpr/ppocr/losses/det_db_loss.py +0 -80
  132. pyxlpr/ppocr/losses/det_east_loss.py +0 -63
  133. pyxlpr/ppocr/losses/det_pse_loss.py +0 -149
  134. pyxlpr/ppocr/losses/det_sast_loss.py +0 -121
  135. pyxlpr/ppocr/losses/distillation_loss.py +0 -272
  136. pyxlpr/ppocr/losses/e2e_pg_loss.py +0 -140
  137. pyxlpr/ppocr/losses/kie_sdmgr_loss.py +0 -113
  138. pyxlpr/ppocr/losses/rec_aster_loss.py +0 -99
  139. pyxlpr/ppocr/losses/rec_att_loss.py +0 -39
  140. pyxlpr/ppocr/losses/rec_ctc_loss.py +0 -44
  141. pyxlpr/ppocr/losses/rec_enhanced_ctc_loss.py +0 -70
  142. pyxlpr/ppocr/losses/rec_nrtr_loss.py +0 -30
  143. pyxlpr/ppocr/losses/rec_sar_loss.py +0 -28
  144. pyxlpr/ppocr/losses/rec_srn_loss.py +0 -47
  145. pyxlpr/ppocr/losses/table_att_loss.py +0 -109
  146. pyxlpr/ppocr/metrics/__init__.py +0 -44
  147. pyxlpr/ppocr/metrics/cls_metric.py +0 -45
  148. pyxlpr/ppocr/metrics/det_metric.py +0 -82
  149. pyxlpr/ppocr/metrics/distillation_metric.py +0 -73
  150. pyxlpr/ppocr/metrics/e2e_metric.py +0 -86
  151. pyxlpr/ppocr/metrics/eval_det_iou.py +0 -274
  152. pyxlpr/ppocr/metrics/kie_metric.py +0 -70
  153. pyxlpr/ppocr/metrics/rec_metric.py +0 -75
  154. pyxlpr/ppocr/metrics/table_metric.py +0 -50
  155. pyxlpr/ppocr/modeling/architectures/__init__.py +0 -32
  156. pyxlpr/ppocr/modeling/architectures/base_model.py +0 -88
  157. pyxlpr/ppocr/modeling/architectures/distillation_model.py +0 -60
  158. pyxlpr/ppocr/modeling/backbones/__init__.py +0 -54
  159. pyxlpr/ppocr/modeling/backbones/det_mobilenet_v3.py +0 -268
  160. pyxlpr/ppocr/modeling/backbones/det_resnet_vd.py +0 -246
  161. pyxlpr/ppocr/modeling/backbones/det_resnet_vd_sast.py +0 -285
  162. pyxlpr/ppocr/modeling/backbones/e2e_resnet_vd_pg.py +0 -265
  163. pyxlpr/ppocr/modeling/backbones/kie_unet_sdmgr.py +0 -186
  164. pyxlpr/ppocr/modeling/backbones/rec_mobilenet_v3.py +0 -138
  165. pyxlpr/ppocr/modeling/backbones/rec_mv1_enhance.py +0 -258
  166. pyxlpr/ppocr/modeling/backbones/rec_nrtr_mtb.py +0 -48
  167. pyxlpr/ppocr/modeling/backbones/rec_resnet_31.py +0 -210
  168. pyxlpr/ppocr/modeling/backbones/rec_resnet_aster.py +0 -143
  169. pyxlpr/ppocr/modeling/backbones/rec_resnet_fpn.py +0 -307
  170. pyxlpr/ppocr/modeling/backbones/rec_resnet_vd.py +0 -286
  171. pyxlpr/ppocr/modeling/heads/__init__.py +0 -54
  172. pyxlpr/ppocr/modeling/heads/cls_head.py +0 -52
  173. pyxlpr/ppocr/modeling/heads/det_db_head.py +0 -118
  174. pyxlpr/ppocr/modeling/heads/det_east_head.py +0 -121
  175. pyxlpr/ppocr/modeling/heads/det_pse_head.py +0 -37
  176. pyxlpr/ppocr/modeling/heads/det_sast_head.py +0 -128
  177. pyxlpr/ppocr/modeling/heads/e2e_pg_head.py +0 -253
  178. pyxlpr/ppocr/modeling/heads/kie_sdmgr_head.py +0 -206
  179. pyxlpr/ppocr/modeling/heads/multiheadAttention.py +0 -163
  180. pyxlpr/ppocr/modeling/heads/rec_aster_head.py +0 -393
  181. pyxlpr/ppocr/modeling/heads/rec_att_head.py +0 -202
  182. pyxlpr/ppocr/modeling/heads/rec_ctc_head.py +0 -88
  183. pyxlpr/ppocr/modeling/heads/rec_nrtr_head.py +0 -826
  184. pyxlpr/ppocr/modeling/heads/rec_sar_head.py +0 -402
  185. pyxlpr/ppocr/modeling/heads/rec_srn_head.py +0 -280
  186. pyxlpr/ppocr/modeling/heads/self_attention.py +0 -406
  187. pyxlpr/ppocr/modeling/heads/table_att_head.py +0 -246
  188. pyxlpr/ppocr/modeling/necks/__init__.py +0 -32
  189. pyxlpr/ppocr/modeling/necks/db_fpn.py +0 -111
  190. pyxlpr/ppocr/modeling/necks/east_fpn.py +0 -188
  191. pyxlpr/ppocr/modeling/necks/fpn.py +0 -138
  192. pyxlpr/ppocr/modeling/necks/pg_fpn.py +0 -314
  193. pyxlpr/ppocr/modeling/necks/rnn.py +0 -92
  194. pyxlpr/ppocr/modeling/necks/sast_fpn.py +0 -284
  195. pyxlpr/ppocr/modeling/necks/table_fpn.py +0 -110
  196. pyxlpr/ppocr/modeling/transforms/__init__.py +0 -28
  197. pyxlpr/ppocr/modeling/transforms/stn.py +0 -135
  198. pyxlpr/ppocr/modeling/transforms/tps.py +0 -308
  199. pyxlpr/ppocr/modeling/transforms/tps_spatial_transformer.py +0 -156
  200. pyxlpr/ppocr/optimizer/__init__.py +0 -61
  201. pyxlpr/ppocr/optimizer/learning_rate.py +0 -228
  202. pyxlpr/ppocr/optimizer/lr_scheduler.py +0 -49
  203. pyxlpr/ppocr/optimizer/optimizer.py +0 -160
  204. pyxlpr/ppocr/optimizer/regularizer.py +0 -52
  205. pyxlpr/ppocr/postprocess/__init__.py +0 -55
  206. pyxlpr/ppocr/postprocess/cls_postprocess.py +0 -33
  207. pyxlpr/ppocr/postprocess/db_postprocess.py +0 -234
  208. pyxlpr/ppocr/postprocess/east_postprocess.py +0 -143
  209. pyxlpr/ppocr/postprocess/locality_aware_nms.py +0 -200
  210. pyxlpr/ppocr/postprocess/pg_postprocess.py +0 -52
  211. pyxlpr/ppocr/postprocess/pse_postprocess/__init__.py +0 -15
  212. pyxlpr/ppocr/postprocess/pse_postprocess/pse/__init__.py +0 -29
  213. pyxlpr/ppocr/postprocess/pse_postprocess/pse/setup.py +0 -14
  214. pyxlpr/ppocr/postprocess/pse_postprocess/pse_postprocess.py +0 -118
  215. pyxlpr/ppocr/postprocess/rec_postprocess.py +0 -654
  216. pyxlpr/ppocr/postprocess/sast_postprocess.py +0 -355
  217. pyxlpr/ppocr/tools/__init__.py +0 -14
  218. pyxlpr/ppocr/tools/eval.py +0 -83
  219. pyxlpr/ppocr/tools/export_center.py +0 -77
  220. pyxlpr/ppocr/tools/export_model.py +0 -129
  221. pyxlpr/ppocr/tools/infer/predict_cls.py +0 -151
  222. pyxlpr/ppocr/tools/infer/predict_det.py +0 -300
  223. pyxlpr/ppocr/tools/infer/predict_e2e.py +0 -169
  224. pyxlpr/ppocr/tools/infer/predict_rec.py +0 -414
  225. pyxlpr/ppocr/tools/infer/predict_system.py +0 -204
  226. pyxlpr/ppocr/tools/infer/utility.py +0 -629
  227. pyxlpr/ppocr/tools/infer_cls.py +0 -83
  228. pyxlpr/ppocr/tools/infer_det.py +0 -134
  229. pyxlpr/ppocr/tools/infer_e2e.py +0 -122
  230. pyxlpr/ppocr/tools/infer_kie.py +0 -153
  231. pyxlpr/ppocr/tools/infer_rec.py +0 -146
  232. pyxlpr/ppocr/tools/infer_table.py +0 -107
  233. pyxlpr/ppocr/tools/program.py +0 -596
  234. pyxlpr/ppocr/tools/test_hubserving.py +0 -117
  235. pyxlpr/ppocr/tools/train.py +0 -163
  236. pyxlpr/ppocr/tools/xlprog.py +0 -748
  237. pyxlpr/ppocr/utils/EN_symbol_dict.txt +0 -94
  238. pyxlpr/ppocr/utils/__init__.py +0 -24
  239. pyxlpr/ppocr/utils/dict/ar_dict.txt +0 -117
  240. pyxlpr/ppocr/utils/dict/arabic_dict.txt +0 -162
  241. pyxlpr/ppocr/utils/dict/be_dict.txt +0 -145
  242. pyxlpr/ppocr/utils/dict/bg_dict.txt +0 -140
  243. pyxlpr/ppocr/utils/dict/chinese_cht_dict.txt +0 -8421
  244. pyxlpr/ppocr/utils/dict/cyrillic_dict.txt +0 -163
  245. pyxlpr/ppocr/utils/dict/devanagari_dict.txt +0 -167
  246. pyxlpr/ppocr/utils/dict/en_dict.txt +0 -63
  247. pyxlpr/ppocr/utils/dict/fa_dict.txt +0 -136
  248. pyxlpr/ppocr/utils/dict/french_dict.txt +0 -136
  249. pyxlpr/ppocr/utils/dict/german_dict.txt +0 -143
  250. pyxlpr/ppocr/utils/dict/hi_dict.txt +0 -162
  251. pyxlpr/ppocr/utils/dict/it_dict.txt +0 -118
  252. pyxlpr/ppocr/utils/dict/japan_dict.txt +0 -4399
  253. pyxlpr/ppocr/utils/dict/ka_dict.txt +0 -153
  254. pyxlpr/ppocr/utils/dict/korean_dict.txt +0 -3688
  255. pyxlpr/ppocr/utils/dict/latin_dict.txt +0 -185
  256. pyxlpr/ppocr/utils/dict/mr_dict.txt +0 -153
  257. pyxlpr/ppocr/utils/dict/ne_dict.txt +0 -153
  258. pyxlpr/ppocr/utils/dict/oc_dict.txt +0 -96
  259. pyxlpr/ppocr/utils/dict/pu_dict.txt +0 -130
  260. pyxlpr/ppocr/utils/dict/rs_dict.txt +0 -91
  261. pyxlpr/ppocr/utils/dict/rsc_dict.txt +0 -134
  262. pyxlpr/ppocr/utils/dict/ru_dict.txt +0 -125
  263. pyxlpr/ppocr/utils/dict/ta_dict.txt +0 -128
  264. pyxlpr/ppocr/utils/dict/table_dict.txt +0 -277
  265. pyxlpr/ppocr/utils/dict/table_structure_dict.txt +0 -2759
  266. pyxlpr/ppocr/utils/dict/te_dict.txt +0 -151
  267. pyxlpr/ppocr/utils/dict/ug_dict.txt +0 -114
  268. pyxlpr/ppocr/utils/dict/uk_dict.txt +0 -142
  269. pyxlpr/ppocr/utils/dict/ur_dict.txt +0 -137
  270. pyxlpr/ppocr/utils/dict/xi_dict.txt +0 -110
  271. pyxlpr/ppocr/utils/dict90.txt +0 -90
  272. pyxlpr/ppocr/utils/e2e_metric/Deteval.py +0 -574
  273. pyxlpr/ppocr/utils/e2e_metric/polygon_fast.py +0 -83
  274. pyxlpr/ppocr/utils/e2e_utils/extract_batchsize.py +0 -87
  275. pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_fast.py +0 -457
  276. pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_slow.py +0 -592
  277. pyxlpr/ppocr/utils/e2e_utils/pgnet_pp_utils.py +0 -162
  278. pyxlpr/ppocr/utils/e2e_utils/visual.py +0 -162
  279. pyxlpr/ppocr/utils/en_dict.txt +0 -95
  280. pyxlpr/ppocr/utils/gen_label.py +0 -81
  281. pyxlpr/ppocr/utils/ic15_dict.txt +0 -36
  282. pyxlpr/ppocr/utils/iou.py +0 -54
  283. pyxlpr/ppocr/utils/logging.py +0 -69
  284. pyxlpr/ppocr/utils/network.py +0 -84
  285. pyxlpr/ppocr/utils/ppocr_keys_v1.txt +0 -6623
  286. pyxlpr/ppocr/utils/profiler.py +0 -110
  287. pyxlpr/ppocr/utils/save_load.py +0 -150
  288. pyxlpr/ppocr/utils/stats.py +0 -72
  289. pyxlpr/ppocr/utils/utility.py +0 -80
  290. pyxlpr/ppstructure/__init__.py +0 -13
  291. pyxlpr/ppstructure/predict_system.py +0 -187
  292. pyxlpr/ppstructure/table/__init__.py +0 -13
  293. pyxlpr/ppstructure/table/eval_table.py +0 -72
  294. pyxlpr/ppstructure/table/matcher.py +0 -192
  295. pyxlpr/ppstructure/table/predict_structure.py +0 -136
  296. pyxlpr/ppstructure/table/predict_table.py +0 -221
  297. pyxlpr/ppstructure/table/table_metric/__init__.py +0 -16
  298. pyxlpr/ppstructure/table/table_metric/parallel.py +0 -51
  299. pyxlpr/ppstructure/table/table_metric/table_metric.py +0 -247
  300. pyxlpr/ppstructure/table/tablepyxl/__init__.py +0 -13
  301. pyxlpr/ppstructure/table/tablepyxl/style.py +0 -283
  302. pyxlpr/ppstructure/table/tablepyxl/tablepyxl.py +0 -118
  303. pyxlpr/ppstructure/utility.py +0 -71
  304. pyxlpr/xlai.py +0 -10
  305. /pyxllib/{ext/autogui → autogui}/virtualkey.py +0 -0
  306. {pyxllib-0.3.96.dist-info → pyxllib-0.3.197.dist-info/licenses}/LICENSE +0 -0
@@ -1,463 +0,0 @@
1
- #!/usr/bin/env python3
2
- #encoding: UTF-8
3
-
4
- #File: rrc_evaluation_funcs_1_1.py
5
- #Version: 1.1
6
- #Version info: changes for Python 3
7
- #Date: 2019-12-29
8
- #Description: File with useful functions to use by the evaluation scripts in the RRC website.
9
-
10
- import json
11
- import sys;
12
- sys.path.append('/')
13
- import zipfile
14
- import re
15
- import os
16
- import importlib
17
-
18
- def print_help():
19
- sys.stdout.write('Usage: python %s.py -g=<gtFile> -s=<submFile> [-o=<outputFolder> -p=<jsonParams>]' %sys.argv[0])
20
- sys.exit(2)
21
-
22
-
23
- def load_zip_file_keys(file,fileNameRegExp=''):
24
- """
25
- Returns an array with the entries of the ZIP file that match with the regular expression.
26
- The key's are the names or the file or the capturing group definied in the fileNameRegExp
27
- """
28
- try:
29
- archive=zipfile.ZipFile(file, mode='r', allowZip64=True)
30
- except :
31
- raise Exception('Error loading the ZIP archive.')
32
-
33
- pairs = []
34
-
35
- for name in archive.namelist():
36
- addFile = True
37
- keyName = name
38
- if fileNameRegExp!="":
39
- m = re.match(fileNameRegExp,name)
40
- if m == None:
41
- addFile = False
42
- else:
43
- if len(m.groups())>0:
44
- keyName = m.group(1)
45
-
46
- if addFile:
47
- pairs.append( keyName )
48
-
49
- return pairs
50
-
51
-
52
- def load_zip_file(file,fileNameRegExp='',allEntries=False):
53
- """
54
- Returns an array with the contents (filtered by fileNameRegExp) of a ZIP file.
55
- The key's are the names or the file or the capturing group definied in the fileNameRegExp
56
- allEntries validates that all entries in the ZIP file pass the fileNameRegExp
57
- """
58
- try:
59
- archive=zipfile.ZipFile(file, mode='r', allowZip64=True)
60
- except :
61
- raise Exception('Error loading the ZIP archive')
62
-
63
- pairs = []
64
- for name in archive.namelist():
65
- addFile = True
66
- keyName = name
67
- if fileNameRegExp!="":
68
- m = re.match(fileNameRegExp,name)
69
- if m == None:
70
- addFile = False
71
- else:
72
- if len(m.groups())>0:
73
- keyName = m.group(1)
74
-
75
- if addFile:
76
- pairs.append( [ keyName , archive.read(name)] )
77
- else:
78
- if allEntries:
79
- raise Exception('ZIP entry not valid: %s' %name)
80
-
81
- return dict(pairs)
82
-
83
- def decode_utf8(raw):
84
- """
85
- Returns a Unicode object on success, or None on failure
86
- """
87
- try:
88
- return raw.decode('utf-8-sig',errors = 'replace')
89
- except:
90
- return None
91
-
92
- def validate_lines_in_file(fileName,file_contents,CRLF=True,LTRB=True,withTranscription=False,withConfidence=False,imWidth=0,imHeight=0):
93
- """
94
- This function validates that all lines of the file calling the Line validation function for each line
95
- """
96
- utf8File = decode_utf8(file_contents)
97
- if (utf8File is None) :
98
- raise Exception("The file %s is not UTF-8" %fileName)
99
-
100
- lines = utf8File.split( "\r\n" if CRLF else "\n" )
101
- for line in lines:
102
- line = line.replace("\r","").replace("\n","")
103
- if(line != ""):
104
- try:
105
- validate_tl_line(line,LTRB,withTranscription,withConfidence,imWidth,imHeight)
106
- except Exception as e:
107
- raise Exception(("Line in sample not valid. Sample: %s Line: %s Error: %s" %(fileName,line,str(e))).encode('utf-8', 'replace'))
108
-
109
-
110
-
111
- def validate_tl_line(line,LTRB=True,withTranscription=True,withConfidence=True,imWidth=0,imHeight=0):
112
- """
113
- Validate the format of the line. If the line is not valid an exception will be raised.
114
- If maxWidth and maxHeight are specified, all points must be inside the imgage bounds.
115
- Posible values are:
116
- LTRB=True: xmin,ymin,xmax,ymax[,confidence][,transcription]
117
- LTRB=False: x1,y1,x2,y2,x3,y3,x4,y4[,confidence][,transcription]
118
- """
119
- get_tl_line_values(line,LTRB,withTranscription,withConfidence,imWidth,imHeight)
120
-
121
-
122
- def get_tl_line_values(line,LTRB=True,withTranscription=False,withConfidence=False,imWidth=0,imHeight=0):
123
- """
124
- Validate the format of the line. If the line is not valid an exception will be raised.
125
- If maxWidth and maxHeight are specified, all points must be inside the imgage bounds.
126
- Posible values are:
127
- LTRB=True: xmin,ymin,xmax,ymax[,confidence][,transcription]
128
- LTRB=False: x1,y1,x2,y2,x3,y3,x4,y4[,confidence][,transcription]
129
- Returns values from a textline. Points , [Confidences], [Transcriptions]
130
- """
131
- confidence = 0.0
132
- transcription = "";
133
- points = []
134
-
135
- numPoints = 4;
136
-
137
- if LTRB:
138
-
139
- numPoints = 4;
140
-
141
- if withTranscription and withConfidence:
142
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-1].?[0-9]*)\s*,(.*)$',line)
143
- if m == None :
144
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-1].?[0-9]*)\s*,(.*)$',line)
145
- raise Exception("Format incorrect. Should be: xmin,ymin,xmax,ymax,confidence,transcription")
146
- elif withConfidence:
147
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-1].?[0-9]*)\s*$',line)
148
- if m == None :
149
- raise Exception("Format incorrect. Should be: xmin,ymin,xmax,ymax,confidence")
150
- elif withTranscription:
151
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*,(.*)$',line)
152
- if m == None :
153
- raise Exception("Format incorrect. Should be: xmin,ymin,xmax,ymax,transcription")
154
- else:
155
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-9]+)\s*,\s*([0-9]+)\s*,?\s*$',line)
156
- if m == None :
157
- raise Exception("Format incorrect. Should be: xmin,ymin,xmax,ymax")
158
-
159
- xmin = int(m.group(1))
160
- ymin = int(m.group(2))
161
- xmax = int(m.group(3))
162
- ymax = int(m.group(4))
163
- if(xmax<xmin):
164
- raise Exception("Xmax value (%s) not valid (Xmax < Xmin)." %(xmax))
165
- if(ymax<ymin):
166
- raise Exception("Ymax value (%s) not valid (Ymax < Ymin)." %(ymax))
167
-
168
- points = [ float(m.group(i)) for i in range(1, (numPoints+1) ) ]
169
-
170
- if (imWidth>0 and imHeight>0):
171
- validate_point_inside_bounds(xmin,ymin,imWidth,imHeight);
172
- validate_point_inside_bounds(xmax,ymax,imWidth,imHeight);
173
-
174
- else:
175
-
176
- numPoints = 8;
177
-
178
- if withTranscription and withConfidence:
179
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-1].?[0-9]*)\s*,(.*)$',line)
180
- if m == None :
181
- raise Exception("Format incorrect. Should be: x1,y1,x2,y2,x3,y3,x4,y4,confidence,transcription")
182
- elif withConfidence:
183
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*([0-1].?[0-9]*)\s*$',line)
184
- if m == None :
185
- raise Exception("Format incorrect. Should be: x1,y1,x2,y2,x3,y3,x4,y4,confidence")
186
- elif withTranscription:
187
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,(.*)$',line)
188
- if m == None :
189
- raise Exception("Format incorrect. Should be: x1,y1,x2,y2,x3,y3,x4,y4,transcription")
190
- else:
191
- m = re.match(r'^\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*,\s*(-?[0-9]+)\s*$',line)
192
- if m == None :
193
- raise Exception("Format incorrect. Should be: x1,y1,x2,y2,x3,y3,x4,y4")
194
-
195
- points = [ float(m.group(i)) for i in range(1, (numPoints+1) ) ]
196
-
197
- validate_clockwise_points(points)
198
-
199
- if (imWidth>0 and imHeight>0):
200
- validate_point_inside_bounds(points[0],points[1],imWidth,imHeight);
201
- validate_point_inside_bounds(points[2],points[3],imWidth,imHeight);
202
- validate_point_inside_bounds(points[4],points[5],imWidth,imHeight);
203
- validate_point_inside_bounds(points[6],points[7],imWidth,imHeight);
204
-
205
-
206
- if withConfidence:
207
- try:
208
- confidence = float(m.group(numPoints+1))
209
- except ValueError:
210
- raise Exception("Confidence value must be a float")
211
-
212
- if withTranscription:
213
- posTranscription = numPoints + (2 if withConfidence else 1)
214
- transcription = m.group(posTranscription)
215
- m2 = re.match(r'^\s*\"(.*)\"\s*$',transcription)
216
- if m2 != None : #Transcription with double quotes, we extract the value and replace escaped characters
217
- transcription = m2.group(1).replace("\\\\", "\\").replace("\\\"", "\"")
218
-
219
- return points,confidence,transcription
220
-
221
- def get_tl_dict_values(detection,withTranscription=False,withConfidence=False,imWidth=0,imHeight=0,validNumPoints=[],validate_cw=True):
222
- """
223
- Validate the format of the dictionary. If the dictionary is not valid an exception will be raised.
224
- If maxWidth and maxHeight are specified, all points must be inside the imgage bounds.
225
- Posible values:
226
- {"points":[[x1,y1],[x2,y2],[x3,x3],..,[xn,yn]]}
227
- {"points":[[x1,y1],[x2,y2],[x3,x3],..,[xn,yn]],"transcription":"###","confidence":0.4,"illegibility":false}
228
- {"points":[[x1,y1],[x2,y2],[x3,x3],..,[xn,yn]],"transcription":"###","confidence":0.4,"dontCare":false}
229
- Returns values from the dictionary. Points , [Confidences], [Transcriptions]
230
- """
231
- confidence = 0.0
232
- transcription = "";
233
- points = []
234
-
235
- if isinstance(detection, dict) == False :
236
- raise Exception("Incorrect format. Object has to be a dictionary")
237
-
238
- if not 'points' in detection:
239
- raise Exception("Incorrect format. Object has no points key)")
240
-
241
- if isinstance(detection['points'], list) == False :
242
- raise Exception("Incorrect format. Object points key have to be an array)")
243
-
244
- num_points = len(detection['points'])
245
-
246
- if num_points<3 :
247
- raise Exception("Incorrect format. Incorrect number of points. At least 3 points are necessary. Found: " + str(num_points))
248
-
249
- if(len(validNumPoints)>0 and num_points in validNumPoints == False ):
250
- raise Exception("Incorrect format. Incorrect number of points. Only allowed 4,8 or 12 points)")
251
-
252
- for i in range(num_points):
253
- if isinstance(detection['points'][i], list) == False :
254
- raise Exception("Incorrect format. Point #" + str(i+1) + " has to be an array)")
255
-
256
- if len(detection['points'][i]) != 2 :
257
- raise Exception("Incorrect format. Point #" + str(i+1) + " has to be an array with 2 objects(x,y) )")
258
-
259
- if isinstance(detection['points'][i][0], (int,float) ) == False or isinstance(detection['points'][i][1], (int,float) ) == False :
260
- raise Exception("Incorrect format. Point #" + str(i+1) + " childs have to be Integers)")
261
-
262
- if (imWidth>0 and imHeight>0):
263
- validate_point_inside_bounds(detection['points'][i][0],detection['points'][i][1],imWidth,imHeight);
264
-
265
- points.append(float(detection['points'][i][0]))
266
- points.append(float(detection['points'][i][1]))
267
-
268
- if validate_cw :
269
- validate_clockwise_points(points)
270
-
271
- if withConfidence:
272
- if not 'confidence' in detection:
273
- raise Exception("Incorrect format. No confidence key)")
274
-
275
- if isinstance(detection['confidence'], (int,float)) == False :
276
- raise Exception("Incorrect format. Confidence key has to be a float)")
277
-
278
- if detection['confidence']<0 or detection['confidence']>1 :
279
- raise Exception("Incorrect format. Confidence key has to be a float between 0.0 and 1.0")
280
-
281
- confidence = detection['confidence']
282
-
283
- if withTranscription:
284
- if not 'transcription' in detection:
285
- raise Exception("Incorrect format. No transcription key)")
286
-
287
- if isinstance(detection['transcription'], str) == False :
288
- raise Exception("Incorrect format. Transcription has to be a string. Detected: " + type(detection['transcription']).__name__ )
289
-
290
- transcription = detection['transcription']
291
-
292
- if 'illegibility' in detection: #Ensures that if illegibility atribute is present and is True the transcription is set to ### (don't care)
293
- if detection['illegibility'] == True:
294
- transcription = "###"
295
-
296
- if 'dontCare' in detection: #Ensures that if dontCare atribute is present and is True the transcription is set to ### (don't care)
297
- if detection['dontCare'] == True:
298
- transcription = "###"
299
-
300
- return points,confidence,transcription
301
-
302
- def validate_point_inside_bounds(x,y,imWidth,imHeight):
303
- if(x<0 or x>imWidth):
304
- raise Exception("X value (%s) not valid. Image dimensions: (%s,%s)" %(xmin,imWidth,imHeight))
305
- if(y<0 or y>imHeight):
306
- raise Exception("Y value (%s) not valid. Image dimensions: (%s,%s) Sample: %s Line:%s" %(ymin,imWidth,imHeight))
307
-
308
- def validate_clockwise_points(points):
309
- """
310
- Validates that the points are in clockwise order.
311
- """
312
- edge = []
313
- for i in range(len(points)//2):
314
- edge.append( (int(points[(i+1)*2 % len(points)]) - int(points[i*2])) * (int(points[ ((i+1)*2+1) % len(points)]) + int(points[i*2+1])) )
315
- if sum(edge)>0:
316
- raise Exception("Points are not clockwise. The coordinates of bounding points have to be given in clockwise order. Regarding the correct interpretation of 'clockwise' remember that the image coordinate system used is the standard one, with the image origin at the upper left, the X axis extending to the right and Y axis extending downwards.")
317
-
318
- def get_tl_line_values_from_file_contents(content,CRLF=True,LTRB=True,withTranscription=False,withConfidence=False,imWidth=0,imHeight=0,sort_by_confidences=True):
319
- """
320
- Returns all points, confindences and transcriptions of a file in lists. Valid line formats:
321
- xmin,ymin,xmax,ymax,[confidence],[transcription]
322
- x1,y1,x2,y2,x3,y3,x4,y4,[confidence],[transcription]
323
- """
324
- if isinstance(content, str):
325
- # 官方原版的功能
326
- pointsList = []
327
- transcriptionsList = []
328
- confidencesList = []
329
-
330
- lines = content.split( "\r\n" if CRLF else "\n" )
331
- for line in lines:
332
- line = line.replace("\r","").replace("\n","")
333
- if(line != "") :
334
- points, confidence, transcription = get_tl_line_values(line,LTRB,withTranscription,withConfidence,imWidth,imHeight);
335
- pointsList.append(points)
336
- transcriptionsList.append(transcription)
337
- confidencesList.append(confidence)
338
-
339
- if withConfidence and len(confidencesList)>0 and sort_by_confidences:
340
- import numpy as np
341
- sorted_ind = np.argsort(-np.array(confidencesList))
342
- confidencesList = [confidencesList[i] for i in sorted_ind]
343
- pointsList = [pointsList[i] for i in sorted_ind]
344
- transcriptionsList = [transcriptionsList[i] for i in sorted_ind]
345
-
346
- return pointsList,confidencesList,transcriptionsList
347
- else:
348
- # 目前扩展支持直接输入pointsList功能
349
- n = len(content)
350
- return content, [0] * n, [''] * n
351
-
352
-
353
- def get_tl_dict_values_from_array(array,withTranscription=False,withConfidence=False,imWidth=0,imHeight=0,sort_by_confidences=True,validNumPoints=[],validate_cw=True):
354
- """
355
- Returns all points, confindences and transcriptions of a file in lists. Valid dict formats:
356
- {"points":[[x1,y1],[x2,y2],[x3,x3],..,[xn,yn]],"transcription":"###","confidence":0.4}
357
- """
358
- pointsList = []
359
- transcriptionsList = []
360
- confidencesList = []
361
-
362
- for n in range(len(array)):
363
- objectDict = array[n]
364
- points, confidence, transcription = get_tl_dict_values(objectDict,withTranscription,withConfidence,imWidth,imHeight,validNumPoints,validate_cw);
365
- pointsList.append(points)
366
- transcriptionsList.append(transcription)
367
- confidencesList.append(confidence)
368
-
369
- if withConfidence and len(confidencesList)>0 and sort_by_confidences:
370
- import numpy as np
371
- sorted_ind = np.argsort(-np.array(confidencesList))
372
- confidencesList = [confidencesList[i] for i in sorted_ind]
373
- pointsList = [pointsList[i] for i in sorted_ind]
374
- transcriptionsList = [transcriptionsList[i] for i in sorted_ind]
375
-
376
- return pointsList,confidencesList,transcriptionsList
377
-
378
- def main_evaluation(p,default_evaluation_params_fn,validate_data_fn,evaluate_method_fn,show_result=True,per_sample=True):
379
- """
380
- This process validates a method, evaluates it and if it succed generates a ZIP file with a JSON entry for each sample.
381
- Params:
382
- p: Dictionary of parmeters with the GT/submission locations. If None is passed, the parameters send by the system are used.
383
- default_evaluation_params_fn: points to a function that returns a dictionary with the default parameters used for the evaluation
384
- validate_data_fn: points to a method that validates the corrct format of the submission
385
- evaluate_method_fn: points to a function that evaluated the submission and return a Dictionary with the results
386
- """
387
-
388
- if (p == None):
389
- p = dict([s[1:].split('=') for s in sys.argv[1:]])
390
- if(len(sys.argv)<3):
391
- print_help()
392
-
393
- evalParams = default_evaluation_params_fn()
394
- if 'p' in p.keys():
395
- evalParams.update( p['p'] if isinstance(p['p'], dict) else json.loads(p['p']) )
396
-
397
- resDict={'calculated':True,'Message':'','method':'{}','per_sample':'{}'}
398
- try:
399
- validate_data_fn(p['g'], p['s'], evalParams)
400
- evalData = evaluate_method_fn(p['g'], p['s'], evalParams)
401
- resDict.update(evalData)
402
-
403
- except Exception as e:
404
- resDict['Message']= str(e)
405
- resDict['calculated']=False
406
-
407
- if 'o' in p:
408
- if not os.path.exists(p['o']):
409
- os.makedirs(p['o'])
410
-
411
- resultsOutputname = p['o'] + '/results.zip'
412
- outZip = zipfile.ZipFile(resultsOutputname, mode='w', allowZip64=True)
413
-
414
- del resDict['per_sample']
415
- if 'output_items' in resDict.keys():
416
- del resDict['output_items']
417
-
418
- outZip.writestr('method.json',json.dumps(resDict))
419
-
420
- if not resDict['calculated']:
421
- if show_result:
422
- sys.stderr.write('Error!\n'+ resDict['Message']+'\n\n')
423
- if 'o' in p:
424
- outZip.close()
425
- return resDict
426
-
427
- if 'o' in p:
428
- if per_sample == True:
429
- for k,v in evalData['per_sample'].items():
430
- outZip.writestr( k + '.json',json.dumps(v))
431
-
432
- if 'output_items' in evalData.keys():
433
- for k, v in evalData['output_items'].items():
434
- outZip.writestr( k,v)
435
-
436
- outZip.close()
437
-
438
- if show_result:
439
- sys.stdout.write("Calculated!")
440
- sys.stdout.write(json.dumps(resDict['method']))
441
-
442
- return resDict
443
-
444
-
445
- def main_validation(default_evaluation_params_fn,validate_data_fn):
446
- """
447
- This process validates a method
448
- Params:
449
- default_evaluation_params_fn: points to a function that returns a dictionary with the default parameters used for the evaluation
450
- validate_data_fn: points to a method that validates the corrct format of the submission
451
- """
452
- try:
453
- p = dict([s[1:].split('=') for s in sys.argv[1:]])
454
- evalParams = default_evaluation_params_fn()
455
- if 'p' in p.keys():
456
- evalParams.update( p['p'] if isinstance(p['p'], dict) else json.loads(p['p']) )
457
-
458
- validate_data_fn(p['g'], p['s'], evalParams)
459
- print ('SUCCESS')
460
- sys.exit(0)
461
- except Exception as e:
462
- print (str(e))
463
- sys.exit(101)