pyxllib 0.3.117__tar.gz → 0.3.119__tar.gz

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 (349) hide show
  1. {pyxllib-0.3.117/pyxllib.egg-info → pyxllib-0.3.119}/PKG-INFO +1 -1
  2. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/pupil.py +30 -0
  3. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/pglib.py +20 -5
  4. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/sqlite.py +3 -1
  5. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/drissionlib.py +67 -9
  6. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/kq5034lib.py +0 -19
  7. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/specialist/filelib.py +40 -11
  8. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/xlsxlib.py +16 -4
  9. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/pupil.py +11 -1
  10. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/browser.py +3 -0
  11. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/tictoc.py +10 -7
  12. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/charclasslib.py +6 -1
  13. {pyxllib-0.3.117 → pyxllib-0.3.119/pyxllib.egg-info}/PKG-INFO +1 -1
  14. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib.egg-info/requires.txt +13 -14
  15. {pyxllib-0.3.117 → pyxllib-0.3.119}/setup.py +3 -2
  16. {pyxllib-0.3.117 → pyxllib-0.3.119}/LICENSE +0 -0
  17. {pyxllib-0.3.117 → pyxllib-0.3.119}/MANIFEST.in +0 -0
  18. {pyxllib-0.3.117 → pyxllib-0.3.119}/README.md +0 -0
  19. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/__init__.py +0 -0
  20. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/__init__.py +0 -0
  21. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/disjoint.py +0 -0
  22. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/geo.py +0 -0
  23. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/intervals.py +0 -0
  24. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/matcher.py +0 -0
  25. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/newbie.py +0 -0
  26. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/shapelylib.py +0 -0
  27. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/specialist.py +0 -0
  28. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/stat.py +0 -0
  29. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/treelib.py +0 -0
  30. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/algo/unitlib.py +0 -0
  31. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/__init__.py +0 -0
  32. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/expert.py +0 -0
  33. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/imfile.py +0 -0
  34. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/imhash.py +0 -0
  35. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/pupil.py +0 -0
  36. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/rgbfmt.py +0 -0
  37. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/trackbartools.py +0 -0
  38. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/xlcvlib.py +0 -0
  39. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/cv/xlpillib.py +0 -0
  40. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/__init__.py +0 -0
  41. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/echarts.py +0 -0
  42. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/jsonlib.py +0 -0
  43. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/oss.py +0 -0
  44. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/data/sqllib.py +0 -0
  45. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/JLineViewer.py +0 -0
  46. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/__init__.py +0 -0
  47. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/autogui/__init__.py +0 -0
  48. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/autogui/autogui.py +0 -0
  49. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/autogui/virtualkey.py +0 -0
  50. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/demolib.py +0 -0
  51. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/old.py +0 -0
  52. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/qt.py +0 -0
  53. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/robustprocfile.py +0 -0
  54. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/seleniumlib.py +0 -0
  55. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/tk.py +0 -0
  56. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/unixlib.py +0 -0
  57. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/utools.py +0 -0
  58. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/webhook.py +0 -0
  59. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/win32lib.py +0 -0
  60. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/ext/yuquelib.py +0 -0
  61. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/__init__.py +0 -0
  62. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/docxlib.py +0 -0
  63. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/gitlib.py +0 -0
  64. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/libreoffice.py +0 -0
  65. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/movielib.py +0 -0
  66. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/newbie.py +0 -0
  67. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/onenotelib.py +0 -0
  68. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/packlib/__init__.py +0 -0
  69. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/packlib/zipfile.py +0 -0
  70. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/pdflib.py +0 -0
  71. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/pupil.py +0 -0
  72. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/specialist/__init__.py +0 -0
  73. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/specialist/dirlib.py +0 -0
  74. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/file/specialist/download.py +0 -0
  75. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/__init__.py +0 -0
  76. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/cachetools.py +0 -0
  77. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/deprecatedlib.py +0 -0
  78. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/ipyexec.py +0 -0
  79. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/multiprocs.py +0 -0
  80. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/newbie.py +0 -0
  81. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/scheduler.py +0 -0
  82. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/sitepackages.py +0 -0
  83. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/__init__.py +0 -0
  84. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/bc.py +0 -0
  85. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/common.py +0 -0
  86. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/datetime.py +0 -0
  87. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/specialist/xllog.py +0 -0
  88. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/prog/xlosenv.py +0 -0
  89. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/stdlib/__init__.py +0 -0
  90. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/stdlib/tablepyxl/__init__.py +0 -0
  91. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/stdlib/tablepyxl/style.py +0 -0
  92. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/stdlib/tablepyxl/tablepyxl.py +0 -0
  93. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/__init__.py +0 -0
  94. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/ahocorasick.py +0 -0
  95. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/jiebalib.py +0 -0
  96. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/jinjalib.py +0 -0
  97. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/jscode.py +0 -0
  98. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/latex/__init__.py +0 -0
  99. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/levenshtein.py +0 -0
  100. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/nestenv.py +0 -0
  101. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/newbie.py +0 -0
  102. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/pupil/__init__.py +0 -0
  103. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/pupil/common.py +0 -0
  104. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/pupil/xlalign.py +0 -0
  105. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/pycode.py +0 -0
  106. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/specialist/__init__.py +0 -0
  107. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/specialist/common.py +0 -0
  108. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/specialist/ptag.py +0 -0
  109. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/spellchecker.py +0 -0
  110. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/vbacode.py +0 -0
  111. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/text/xmllib.py +0 -0
  112. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/xl.py +0 -0
  113. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib/xlcv.py +0 -0
  114. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib.egg-info/SOURCES.txt +0 -0
  115. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib.egg-info/dependency_links.txt +0 -0
  116. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxllib.egg-info/top_level.txt +0 -0
  117. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/__init__.py +0 -0
  118. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/__init__.py +0 -0
  119. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/clientlib.py +0 -0
  120. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/specialist.py +0 -0
  121. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/torch_app.py +0 -0
  122. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/xlpaddle.py +0 -0
  123. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ai/xltorch.py +0 -0
  124. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/__init__.py +0 -0
  125. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/coco.py +0 -0
  126. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/datacls.py +0 -0
  127. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/datasets.py +0 -0
  128. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/gptlib.py +0 -0
  129. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/icdar/__init__.py +0 -0
  130. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/icdar/deteval.py +0 -0
  131. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/icdar/icdar2013.py +0 -0
  132. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/icdar/iou.py +0 -0
  133. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/icdar/rrc_evaluation_funcs_1_1.py +0 -0
  134. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/imtextline.py +0 -0
  135. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/labelme.py +0 -0
  136. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/removeline.py +0 -0
  137. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/specialist.py +0 -0
  138. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/data/tiktokenlib.py +0 -0
  139. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/eval/__init__.py +0 -0
  140. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/paddleocr.py +0 -0
  141. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/__init__.py +0 -0
  142. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/configs/rec/multi_language/generate_multi_language_configs.py +0 -0
  143. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/__init__.py +0 -0
  144. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/ColorJitter.py +0 -0
  145. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/__init__.py +0 -0
  146. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/copy_paste.py +0 -0
  147. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/east_process.py +0 -0
  148. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/gen_table_mask.py +0 -0
  149. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/iaa_augment.py +0 -0
  150. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/label_ops.py +0 -0
  151. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/make_border_map.py +0 -0
  152. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/make_pse_gt.py +0 -0
  153. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/make_shrink_map.py +0 -0
  154. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/operators.py +0 -0
  155. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/pg_process.py +0 -0
  156. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/randaugment.py +0 -0
  157. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/random_crop_data.py +0 -0
  158. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/rec_img_aug.py +0 -0
  159. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/sast_process.py +0 -0
  160. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/text_image_aug/__init__.py +0 -0
  161. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/text_image_aug/augment.py +0 -0
  162. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/imaug/text_image_aug/warp_mls.py +0 -0
  163. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/lmdb_dataset.py +0 -0
  164. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/pgnet_dataset.py +0 -0
  165. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/pubtab_dataset.py +0 -0
  166. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/data/simple_dataset.py +0 -0
  167. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/__init__.py +0 -0
  168. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/ace_loss.py +0 -0
  169. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/basic_loss.py +0 -0
  170. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/center_loss.py +0 -0
  171. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/cls_loss.py +0 -0
  172. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/combined_loss.py +0 -0
  173. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/det_basic_loss.py +0 -0
  174. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/det_db_loss.py +0 -0
  175. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/det_east_loss.py +0 -0
  176. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/det_pse_loss.py +0 -0
  177. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/det_sast_loss.py +0 -0
  178. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/distillation_loss.py +0 -0
  179. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/e2e_pg_loss.py +0 -0
  180. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/kie_sdmgr_loss.py +0 -0
  181. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_aster_loss.py +0 -0
  182. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_att_loss.py +0 -0
  183. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_ctc_loss.py +0 -0
  184. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_enhanced_ctc_loss.py +0 -0
  185. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_nrtr_loss.py +0 -0
  186. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_sar_loss.py +0 -0
  187. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/rec_srn_loss.py +0 -0
  188. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/losses/table_att_loss.py +0 -0
  189. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/__init__.py +0 -0
  190. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/cls_metric.py +0 -0
  191. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/det_metric.py +0 -0
  192. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/distillation_metric.py +0 -0
  193. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/e2e_metric.py +0 -0
  194. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/eval_det_iou.py +0 -0
  195. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/kie_metric.py +0 -0
  196. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/rec_metric.py +0 -0
  197. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/metrics/table_metric.py +0 -0
  198. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/architectures/__init__.py +0 -0
  199. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/architectures/base_model.py +0 -0
  200. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/architectures/distillation_model.py +0 -0
  201. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/__init__.py +0 -0
  202. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/det_mobilenet_v3.py +0 -0
  203. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/det_resnet_vd.py +0 -0
  204. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/det_resnet_vd_sast.py +0 -0
  205. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/e2e_resnet_vd_pg.py +0 -0
  206. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/kie_unet_sdmgr.py +0 -0
  207. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_mobilenet_v3.py +0 -0
  208. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_mv1_enhance.py +0 -0
  209. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_nrtr_mtb.py +0 -0
  210. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_resnet_31.py +0 -0
  211. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_resnet_aster.py +0 -0
  212. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_resnet_fpn.py +0 -0
  213. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/backbones/rec_resnet_vd.py +0 -0
  214. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/__init__.py +0 -0
  215. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/cls_head.py +0 -0
  216. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/det_db_head.py +0 -0
  217. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/det_east_head.py +0 -0
  218. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/det_pse_head.py +0 -0
  219. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/det_sast_head.py +0 -0
  220. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/e2e_pg_head.py +0 -0
  221. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/kie_sdmgr_head.py +0 -0
  222. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/multiheadAttention.py +0 -0
  223. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_aster_head.py +0 -0
  224. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_att_head.py +0 -0
  225. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_ctc_head.py +0 -0
  226. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_nrtr_head.py +0 -0
  227. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_sar_head.py +0 -0
  228. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/rec_srn_head.py +0 -0
  229. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/self_attention.py +0 -0
  230. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/heads/table_att_head.py +0 -0
  231. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/__init__.py +0 -0
  232. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/db_fpn.py +0 -0
  233. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/east_fpn.py +0 -0
  234. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/fpn.py +0 -0
  235. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/pg_fpn.py +0 -0
  236. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/rnn.py +0 -0
  237. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/sast_fpn.py +0 -0
  238. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/necks/table_fpn.py +0 -0
  239. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/transforms/__init__.py +0 -0
  240. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/transforms/stn.py +0 -0
  241. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/transforms/tps.py +0 -0
  242. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/modeling/transforms/tps_spatial_transformer.py +0 -0
  243. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/optimizer/__init__.py +0 -0
  244. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/optimizer/learning_rate.py +0 -0
  245. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/optimizer/lr_scheduler.py +0 -0
  246. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/optimizer/optimizer.py +0 -0
  247. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/optimizer/regularizer.py +0 -0
  248. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/__init__.py +0 -0
  249. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/cls_postprocess.py +0 -0
  250. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/db_postprocess.py +0 -0
  251. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/east_postprocess.py +0 -0
  252. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/locality_aware_nms.py +0 -0
  253. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/pg_postprocess.py +0 -0
  254. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/pse_postprocess/__init__.py +0 -0
  255. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/pse_postprocess/pse/__init__.py +0 -0
  256. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/pse_postprocess/pse/setup.py +0 -0
  257. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/pse_postprocess/pse_postprocess.py +0 -0
  258. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/rec_postprocess.py +0 -0
  259. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/postprocess/sast_postprocess.py +0 -0
  260. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/__init__.py +0 -0
  261. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/eval.py +0 -0
  262. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/export_center.py +0 -0
  263. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/export_model.py +0 -0
  264. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/predict_cls.py +0 -0
  265. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/predict_det.py +0 -0
  266. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/predict_e2e.py +0 -0
  267. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/predict_rec.py +0 -0
  268. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/predict_system.py +0 -0
  269. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer/utility.py +0 -0
  270. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_cls.py +0 -0
  271. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_det.py +0 -0
  272. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_e2e.py +0 -0
  273. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_kie.py +0 -0
  274. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_rec.py +0 -0
  275. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/infer_table.py +0 -0
  276. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/program.py +0 -0
  277. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/test_hubserving.py +0 -0
  278. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/train.py +0 -0
  279. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/tools/xlprog.py +0 -0
  280. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/EN_symbol_dict.txt +0 -0
  281. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/__init__.py +0 -0
  282. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ar_dict.txt +0 -0
  283. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/arabic_dict.txt +0 -0
  284. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/be_dict.txt +0 -0
  285. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/bg_dict.txt +0 -0
  286. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/chinese_cht_dict.txt +0 -0
  287. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/cyrillic_dict.txt +0 -0
  288. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/devanagari_dict.txt +0 -0
  289. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/en_dict.txt +0 -0
  290. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/fa_dict.txt +0 -0
  291. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/french_dict.txt +0 -0
  292. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/german_dict.txt +0 -0
  293. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/hi_dict.txt +0 -0
  294. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/it_dict.txt +0 -0
  295. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/japan_dict.txt +0 -0
  296. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ka_dict.txt +0 -0
  297. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/korean_dict.txt +0 -0
  298. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/latin_dict.txt +0 -0
  299. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/mr_dict.txt +0 -0
  300. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ne_dict.txt +0 -0
  301. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/oc_dict.txt +0 -0
  302. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/pu_dict.txt +0 -0
  303. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/rs_dict.txt +0 -0
  304. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/rsc_dict.txt +0 -0
  305. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ru_dict.txt +0 -0
  306. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ta_dict.txt +0 -0
  307. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/table_dict.txt +0 -0
  308. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/table_structure_dict.txt +0 -0
  309. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/te_dict.txt +0 -0
  310. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ug_dict.txt +0 -0
  311. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/uk_dict.txt +0 -0
  312. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/ur_dict.txt +0 -0
  313. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict/xi_dict.txt +0 -0
  314. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/dict90.txt +0 -0
  315. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_metric/Deteval.py +0 -0
  316. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_metric/polygon_fast.py +0 -0
  317. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_utils/extract_batchsize.py +0 -0
  318. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_fast.py +0 -0
  319. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_slow.py +0 -0
  320. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_utils/pgnet_pp_utils.py +0 -0
  321. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/e2e_utils/visual.py +0 -0
  322. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/en_dict.txt +0 -0
  323. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/gen_label.py +0 -0
  324. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/ic15_dict.txt +0 -0
  325. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/iou.py +0 -0
  326. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/logging.py +0 -0
  327. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/network.py +0 -0
  328. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/ppocr_keys_v1.txt +0 -0
  329. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/profiler.py +0 -0
  330. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/save_load.py +0 -0
  331. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/stats.py +0 -0
  332. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppocr/utils/utility.py +0 -0
  333. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/__init__.py +0 -0
  334. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/predict_system.py +0 -0
  335. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/__init__.py +0 -0
  336. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/eval_table.py +0 -0
  337. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/matcher.py +0 -0
  338. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/predict_structure.py +0 -0
  339. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/predict_table.py +0 -0
  340. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/table_metric/__init__.py +0 -0
  341. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/table_metric/parallel.py +0 -0
  342. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/table_metric/table_metric.py +0 -0
  343. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/tablepyxl/__init__.py +0 -0
  344. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/tablepyxl/style.py +0 -0
  345. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/table/tablepyxl/tablepyxl.py +0 -0
  346. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/ppstructure/utility.py +0 -0
  347. {pyxllib-0.3.117 → pyxllib-0.3.119}/pyxlpr/xlai.py +0 -0
  348. {pyxllib-0.3.117 → pyxllib-0.3.119}/requirements.txt +0 -0
  349. {pyxllib-0.3.117 → pyxllib-0.3.119}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pyxllib
3
- Version: 0.3.117
3
+ Version: 0.3.119
4
4
  Summary: 厦门理工模式识别团队通用python代码工具库
5
5
  Home-page: https://github.com/XLPRUtils/pyxllib
6
6
  Author: code4101
@@ -157,6 +157,9 @@ class ValuesStat:
157
157
 
158
158
  class ValuesStat2:
159
159
  """ 240509周四17:33,第2代统计器
160
+
161
+ 240628周五14:05 todo 关于各种特殊格式数据,怎么计算是个问题
162
+ 这问题可能有些复杂,近期估计没空折腾,留以后有空折腾的一个大坑了
160
163
  """
161
164
 
162
165
  def __init__(self, values=None, raw_values=None, data_type=None):
@@ -307,6 +310,33 @@ class ValuesStat2:
307
310
 
308
311
  return ratio_dict
309
312
 
313
+ def group_count(self, max_entries=None, min_count=None):
314
+ """ 统计每种取值出现的次数,并根据条件过滤结果
315
+
316
+ :param max_entries: 最多显示的条目数
317
+ :param min_count: 显示的条目至少出现的次数
318
+ """
319
+ from collections import Counter
320
+
321
+ # 使用Counter来计数每个值出现的次数
322
+ counts = Counter(self.values or self.raw_values)
323
+
324
+ # 根据min_count过滤计数结果
325
+ if min_count is not None:
326
+ counts = {k: v for k, v in counts.items() if v >= min_count}
327
+
328
+ # 根据max_entries限制结果数量
329
+ if max_entries is not None:
330
+ # 按出现次数降序排列,然后选取前max_entries项
331
+ most_common = counts.most_common(max_entries)
332
+ # 转换回字典形式
333
+ counts = dict(most_common)
334
+ else:
335
+ # 如果没有指定max_entries,则保持所有满足min_count的结果
336
+ counts = dict(sorted(counts.items(), key=lambda item: item[1], reverse=True))
337
+
338
+ return counts
339
+
310
340
 
311
341
  class Groups:
312
342
  def __init__(self, data):
@@ -42,7 +42,7 @@ import psycopg
42
42
  import psycopg.rows
43
43
 
44
44
  from pyxllib.prog.newbie import round_int, human_readable_number
45
- from pyxllib.prog.pupil import utc_now, utc_timestamp
45
+ from pyxllib.prog.pupil import utc_now, utc_timestamp, is_valid_identifier
46
46
  from pyxllib.prog.specialist import XlOsEnv
47
47
  from pyxllib.algo.pupil import ValuesStat2
48
48
  from pyxllib.file.specialist import get_etag, StreamJsonlWriter
@@ -271,12 +271,14 @@ WHERE {table_name}.{item_id_name} = cte.{item_id_name}"""
271
271
  def __6_高级统计(self):
272
272
  pass
273
273
 
274
- def get_column_valuesstat(self, table_name, column, percentile_count=5,
275
- filter_condition=None, by_data=False):
274
+ def get_column_valuesstat(self, table_name, column, filter_condition=None,
275
+ percentile_count=5,
276
+ by_data=False, data_type=None):
276
277
  """ 获得指定表格的某个字段的统计特征ValuesStat2对象
277
278
 
278
279
  :param table_name: 表名
279
280
  :param column: 用于计算统计数据的字段名
281
+ 不一定是标准的字段名
280
282
  :param percentile_count: 分位数的数量,例如 3 表示只计算中位数
281
283
  :param by_data: 是否获得原始数据
282
284
  默认只获得统计特征,不获得原始数据
@@ -289,7 +291,15 @@ WHERE {table_name}.{item_id_name} = cte.{item_id_name}"""
289
291
  values = self.exec2col(sql.build_select(column))
290
292
  if data_type == 'numeric':
291
293
  values = [x and float(x) for x in values]
292
- return ValuesStat2(raw_values=values, data_type=data_type)
294
+ vs = ValuesStat2(raw_values=values, data_type=data_type)
295
+
296
+ if data_type == 'text' and is_valid_identifier(column):
297
+ vs0 = self.get_column_valuesstat(table_name, column, filter_condition=filter_condition,
298
+ percentile_count=percentile_count, by_data=False)
299
+ vs.n = vs0.n
300
+ vs.dist = vs0.dist
301
+
302
+ return vs
293
303
 
294
304
  def init_from_db():
295
305
  # 1 构建基础的 SQL 查询
@@ -341,7 +351,12 @@ WHERE {table_name}.{item_id_name} = cte.{item_id_name}"""
341
351
 
342
352
  return x
343
353
 
344
- data_type = self.get_column_data_type(table_name, column)
354
+ data_type = data_type or self.get_column_data_type(table_name, column)
355
+
356
+ # 如果不是标准的列名,强制获取数据
357
+ if not is_valid_identifier(column):
358
+ by_data = True
359
+
345
360
  if by_data:
346
361
  vs = init_from_db_data()
347
362
  else:
@@ -89,6 +89,8 @@ class SqlBuilder:
89
89
  """ 使用一种特殊的格式化标记来设置规则
90
90
 
91
91
  :param desc: 例如 'id%2=1'
92
+
93
+ todo 我好像傻了,画蛇添足,这个功能好像直接用 .where 就能完成~
92
94
  """
93
95
  if not desc:
94
96
  return
@@ -148,6 +150,7 @@ class SqlBuilder:
148
150
  sql.append(f"WHERE {' AND '.join(self._where)}")
149
151
  return '\n'.join(sql)
150
152
 
153
+
151
154
  def __3_build_中级命令(self):
152
155
  pass
153
156
 
@@ -168,7 +171,6 @@ class SqlBuilder:
168
171
  sql._where = self._where.copy()
169
172
  return sql.build_select()
170
173
 
171
-
172
174
  class SqlBase:
173
175
  """ Sql语法通用的功能 """
174
176
 
@@ -3,6 +3,7 @@
3
3
  # @Author : 陈坤泽
4
4
  # @Email : 877362867@qq.com
5
5
  # @Date : 2024/04/12
6
+ import time
6
7
 
7
8
  from pyxllib.prog.pupil import check_install_package
8
9
 
@@ -13,10 +14,41 @@ from urllib.parse import unquote
13
14
 
14
15
  import DrissionPage
15
16
  from DrissionPage import ChromiumPage
17
+ from DrissionPage._pages.chromium_base import ChromiumBase
18
+ from DrissionPage._pages.chromium_tab import ChromiumTab
16
19
  from DrissionPage._base.base import BasePage, BaseElement
17
20
 
18
21
  from pyxllib.prog.pupil import inject_members
19
22
  from pyxllib.text.pupil import strfind
23
+ from pyxllib.file.specialist import GetEtag
24
+
25
+
26
+ def get_dp_page(dp_page=None) -> 'XlPage':
27
+ """
28
+
29
+ :param dp_page:
30
+ 默认None, 返回默认的page,一般就是当前页面
31
+ True, 新建一个page
32
+ str, 新建一个对应url的page
33
+ func(tab), 通过规则筛选tab,返回符合条件的第1个tab,否则新建一个tab
34
+ """
35
+
36
+ if isinstance(dp_page, ChromiumPage):
37
+ return dp_page
38
+ elif isinstance(dp_page, ChromiumTab):
39
+ return dp_page.page
40
+ elif callable(dp_page):
41
+ page0 = ChromiumPage()
42
+ for tab in page0.get_tabs():
43
+ if dp_page(tab):
44
+ return tab.page
45
+ return page0.new_tab().page
46
+ elif dp_page is True:
47
+ return ChromiumPage().new_tab().page
48
+ elif isinstance(dp_page, str):
49
+ return ChromiumPage().new_tab(dp_page).page
50
+ else:
51
+ return ChromiumPage()
20
52
 
21
53
 
22
54
  def get_latest_not_dev_tab(page=None):
@@ -46,7 +78,7 @@ def search_download_file(file_name):
46
78
  return file
47
79
 
48
80
 
49
- class XlBasePage(BasePage):
81
+ class XlChromiumBase(ChromiumBase):
50
82
  def get2(self, url, show_errmsg=False, retry=None, interval=None):
51
83
  """
52
84
  240418周四21:57,DrissionPage-4.0.4.21 官方自带page.get,有时候会有bug,不会实际刷新url,这里加个代码进行fix
@@ -65,7 +97,7 @@ class XlBasePage(BasePage):
65
97
  except DrissionPage.errors.ElementLostError:
66
98
  return self
67
99
 
68
- def get_download_files(self):
100
+ def get_download_files(self: ChromiumPage):
69
101
  """ 获取下载列表
70
102
 
71
103
  :param search_name: 搜索文件名,输入该参数时,只会从上往下找到第一个匹配的文件
@@ -80,7 +112,7 @@ class XlBasePage(BasePage):
80
112
  'tag:downloads-item')
81
113
  for item in items:
82
114
  loc = unquote(item.sr('tag:img').attr('src').replace('+', ' '))
83
- file = re.search(r'path=(.+?)(&scale=\d+x)?$', loc).group(1)
115
+ file = re.search(r'path=(.+?)(&scale=(\d+(\.\d+)?)x)?$', loc).group(1)
84
116
 
85
117
  files.append({
86
118
  'file': file,
@@ -91,14 +123,40 @@ class XlBasePage(BasePage):
91
123
 
92
124
  return files
93
125
 
126
+ def wait_page_not_change(self, interval=3):
127
+ """ 等待直到页面内容不再变化
94
128
 
95
- inject_members(XlBasePage, BasePage)
129
+ :param interval: 时间间隔,需要判断当前内容和interval秒后的内容,看内容是否欧发生改变
130
+ """
131
+ last_html, last_etag = None, None
132
+ while True:
133
+ html = self.html
134
+ etag = GetEtag.from_text(html)
135
+ if etag == last_etag:
136
+ break
137
+
138
+ last_html, last_etag = html, etag
139
+ time.sleep(interval)
140
+ return last_html
141
+
142
+ def action_type(self, ele, text, clear=True):
143
+ """ 基于action实现的重写入,常用于日期相关操作
144
+ 因为很多日期类组件,直接使用ele.input是不生效的,哪怕看似显示了文本,但其实并没有触发js改动,需要用动作链来实现
145
+ """
146
+ from DrissionPage.common import Keys
147
+ if clear:
148
+ self.actions.click(ele).key_down(Keys.CTRL).type('a').key_up(Keys.CTRL).type(text)
149
+ else:
150
+ self.actions.click(ele).type(text)
151
+
152
+
153
+ inject_members(XlChromiumBase, ChromiumBase)
96
154
 
97
155
 
98
- class XlBaseElement(BaseElement):
99
- def input2(self, vals, clear=False, by_js=False):
100
- self.clear()
101
- self.input(vals)
156
+ class XlPage(XlChromiumBase, ChromiumTab, ChromiumPage):
157
+ """ 只作为一个类型标记,无实质功能。在猴子补丁背景下,让ide能正确跳转函数定义。 """
158
+ pass
102
159
 
103
160
 
104
- inject_members(XlBaseElement, BaseElement)
161
+ def wait_page_not_change(page, interval=3):
162
+ page.wait_page_not_change(interval)
@@ -883,10 +883,6 @@ class 网课考勤:
883
883
  # 然后自己手动操作验证码
884
884
  # 以及选择"店铺"
885
885
 
886
- def 登录微信支付(self):
887
- driver = self.ensure_driver()
888
- driver.get('https://pay.weixin.qq.com/index.php/core/home/login')
889
-
890
886
  def 下载课次考勤数据(self, 起始课=None, 终止课=None, 文件名前缀=''):
891
887
  if 起始课 is None:
892
888
  起始课 = max(1, self.结束课次)
@@ -944,16 +940,6 @@ class 网课考勤:
944
940
  def 批量退款(self):
945
941
  self.driver.get('https://pay.weixin.qq.com/index.php/xphp/cbatchrefund/batch_refund#/pages/index/index')
946
942
 
947
- def 申请单条退款(self, 凭证号, 退款金额=0, 退款原因=''):
948
- driver = self.ensure_driver()
949
- driver.get('https://pay.weixin.qq.com/index.php/core/refundapply')
950
- driver.locate('//*[@id="app"]/div/div[2]/div[2]/div[2]/div/span/input').send_keys(凭证号)
951
- driver.click('//*[@id="applyRefundBtn"]') # 申请退款
952
- driver.locate('//*[@id="app"]/div/div[2]/div[2]/div[3]/div[2]/div/div[1]/div/span[1]/input').send_keys(
953
- str(退款金额))
954
- driver.locate('//*[@id="textInput"]').send_keys(退款原因)
955
- # driver.click('//*[@id="commitRefundApplyBtn"]') # 建议手动点"提交申请"
956
-
957
943
 
958
944
  class 网课考勤2(网课考勤):
959
945
  def login_xe(self):
@@ -1695,11 +1681,6 @@ def 下载课次考勤数据(课程链接, 检查文本=''):
1695
1681
  driver.click('//*[@id="data-export-container"]/div/div[2]/div/div[2]/div[2]/button[2]/span/span') # 导出
1696
1682
 
1697
1683
 
1698
- def 登录微信支付():
1699
- driver = get_driver()
1700
- driver.get('https://pay.weixin.qq.com/index.php/core/home/login')
1701
-
1702
-
1703
1684
  def 聚合读取考勤数据(data_dir, name, judge_minute=30):
1704
1685
  """
1705
1686
  1、在目录"data_folder"下,找前缀包含name的所有文件
@@ -1124,6 +1124,22 @@ class XlPath(type(pathlib.Path())):
1124
1124
  else:
1125
1125
  return s
1126
1126
 
1127
+ def read_text2(self):
1128
+ """ 智能识别编码的文本读取,这里收集了我见过的一些常见类型 """
1129
+ for encoding in ['utf8',
1130
+ 'gbk',
1131
+ 'gb18030',
1132
+ 'utf_16',
1133
+ 'cp932', # 日文,Shift-JIS
1134
+ 'Big5', # 繁体字,Big5
1135
+ 'big5hkscs', # 繁体字
1136
+ ]:
1137
+ try:
1138
+ content = self.read_text(encoding=encoding)
1139
+ return content, encoding
1140
+ except (UnicodeDecodeError, UnicodeError):
1141
+ continue
1142
+
1127
1143
  def readlines_batch(self, batch_size, *, encoding='utf8'):
1128
1144
  """ 将文本行打包,每次返回一个批次多行数据
1129
1145
 
@@ -1460,20 +1476,33 @@ class XlPath(type(pathlib.Path())):
1460
1476
  else:
1461
1477
  return shutil.copytree(self, dst)
1462
1478
 
1463
- def move(self, dst, if_exists=None):
1479
+ def move(self, dst, *, cross_disk=False, if_exists=None):
1480
+ """
1481
+ :param cross_disk: 是否可能涉及跨磁盘操作
1482
+ """
1464
1483
  if not self.exists():
1465
1484
  return self
1466
1485
 
1467
- dst = XlPath(dst)
1468
- if self == dst:
1469
- # 同一个文件,可能是调整了大小写名称
1470
- if self.as_posix() != dst.as_posix():
1471
- tmp = self.tempfile(dir=self.parent) # self不一定是file,也可能是dir,但这个名称通用
1472
- self.rename(tmp)
1473
- self.delete()
1474
- tmp.rename(dst)
1475
- elif dst.exist_preprcs(if_exists):
1476
- self.rename(dst)
1486
+ if cross_disk: # 显式设置跨磁盘操作
1487
+ dst = self.copy(dst, if_exists=if_exists)
1488
+ self.delete()
1489
+ return dst
1490
+
1491
+ try:
1492
+ dst = XlPath(dst)
1493
+ if self == dst:
1494
+ # 同一个文件,可能是调整了大小写名称
1495
+ if self.as_posix() != dst.as_posix():
1496
+ tmp = self.tempfile(dir=self.parent) # self不一定是file,也可能是dir,但这个名称通用
1497
+ self.rename(tmp)
1498
+ self.delete()
1499
+ tmp.rename(dst)
1500
+ elif dst.exist_preprcs(if_exists):
1501
+ self.rename(dst)
1502
+ except OSError:
1503
+ # 有可能是跨磁盘操作,这个时候就只能先拷贝再删除了
1504
+ dst = self.copy(dst, if_exists=if_exists)
1505
+ self.delete()
1477
1506
  return dst
1478
1507
 
1479
1508
  def rename2(self, new_name, if_exists=None):
@@ -7,6 +7,8 @@
7
7
  """
8
8
  扩展了些自己的openpyxl工具
9
9
  """
10
+ import copy
11
+
10
12
  import time
11
13
 
12
14
  from pyxllib.prog.pupil import check_install_package, run_once
@@ -2463,7 +2465,7 @@ def extract_workbook_summary2(file_path, *,
2463
2465
  """
2464
2466
  :param keep_links: 是否保留外部表格链接数据。如果保留,打开好像会有点问题。
2465
2467
  :param mode:
2466
- 0,最原始的summary3摘要
2468
+ 0,最原始的summary2摘要
2467
2469
  1,添加当前工作表、单元格位置的信息
2468
2470
  :param kwargs: 捕捉其他参数,主要是向下兼容,其实现在并没有用
2469
2471
 
@@ -3015,7 +3017,10 @@ def extract_workbook_summary3b(file_path,
3015
3017
 
3016
3018
  :param summary_limit_len: 摘要长度限制
3017
3019
  :param timeout_seconds: 超时限制
3018
- :param return_mode: 返回模式,0表示只返回摘要,1表示返回摘要和耗时
3020
+ :param return_mode: 返回模式
3021
+ 0,表示只返回摘要
3022
+ 1,表示返回摘要和耗时
3023
+ 2, 再增加返回summary2
3019
3024
  :param len_mode:
3020
3025
  0, 使用len作为token长度评估
3021
3026
  1, 使用模型评估实际token长度
@@ -3024,6 +3029,7 @@ def extract_workbook_summary3b(file_path,
3024
3029
  res = {}
3025
3030
  res['fileName'] = Path(file_path).name
3026
3031
  load_time = summary2_time = summary3_time = -1
3032
+ summary2_res = {}
3027
3033
 
3028
3034
  def reduce_summary(summary):
3029
3035
  """ 如果转json后的summary超过4K,去掉可能的sheets字段 """
@@ -3037,6 +3043,7 @@ def extract_workbook_summary3b(file_path,
3037
3043
  start_time = time.time()
3038
3044
  res, load_time = extract_workbook_summary2(file_path, mode=1, return_mode=1, **kwargs)
3039
3045
  # res = convert_to_json_compatible(res)
3046
+ summary2_res = copy.deepcopy(res)
3040
3047
  summary2_time = time.time() - start_time - load_time
3041
3048
  start_time = time.time()
3042
3049
  if len_mode == 1:
@@ -3055,8 +3062,13 @@ def extract_workbook_summary3b(file_path,
3055
3062
  res['error'] = f'提取摘要时发生错误:{format_exception(e, 2)}'
3056
3063
  reduce_summary(res)
3057
3064
 
3058
- if return_mode == 1:
3059
- return res, {'load_time': human_readable_number(load_time),
3065
+ time_dict = {'load_time': human_readable_number(load_time),
3060
3066
  'summary2_time': human_readable_number(summary2_time),
3061
3067
  'summary3_time': human_readable_number(summary3_time)}
3068
+
3069
+ if return_mode == 1:
3070
+ return res, time_dict
3071
+ elif return_mode == 2:
3072
+ return res, time_dict, summary2_res
3073
+
3062
3074
  return res
@@ -34,6 +34,7 @@ import threading
34
34
  import time
35
35
  import traceback
36
36
  from urllib.parse import urlparse
37
+ import re
37
38
 
38
39
  from pyxllib.prog.newbie import classproperty, typename
39
40
 
@@ -1133,10 +1134,14 @@ def support_multi_processes(default_processes=1):
1133
1134
  if process_id is None:
1134
1135
  return func(*args, **kwargs)
1135
1136
  else:
1136
- return func(*args, **kwargs, process_count=process_count, process_id=process_id)
1137
+ return func(*args, **kwargs, process_count=process_count, process_id=int(process_id))
1137
1138
  else:
1138
1139
  mpl = MultiProcessLauncher()
1139
1140
  for i in range(int(process_count)):
1141
+ if isinstance(process_id, int) and i != process_id:
1142
+ continue
1143
+
1144
+ # todo 这样使用有个坑,process_count、process_id都是以str类型传入的,开发者下游使用容易出问题
1140
1145
  cmds = [func.__name__,
1141
1146
  '--process_count', str(process_count),
1142
1147
  '--process_id', str(i)
@@ -1303,3 +1308,8 @@ def check_counter(data, top_n=10):
1303
1308
  def tprint(*args, **kwargs):
1304
1309
  """ 带时间戳的print """
1305
1310
  print(utc_now2(), *args, **kwargs)
1311
+
1312
+
1313
+ def is_valid_identifier(name):
1314
+ """ 判断是否是合法的标识符 """
1315
+ return re.match(r'^[a-zA-Z_][a-zA-Z0-9_]*$', name)
@@ -230,6 +230,9 @@ class Browser(Explorer):
230
230
  file = file.rename(get_etag(str(file)) + file.suffix, if_exists='replace')
231
231
  self.__call__(arg, file, **kwargs)
232
232
 
233
+ def url(self, *args, wait=True, **kwargs):
234
+ super().__call__(*args, wait=wait, **kwargs)
235
+
233
236
  def __call__(self, arg, file=None, *, wait=True, clsmsg=True, to_html_args=None,
234
237
  **kwargs): # NOQA Browser的操作跟标准接口略有差异
235
238
  """ 该版本会把arg转存文件重设为文件名
@@ -12,6 +12,7 @@ from humanfriendly import format_timespan
12
12
 
13
13
  from pyxllib.algo.pupil import natural_sort, ValuesStat
14
14
  from pyxllib.text.pupil import shorten, listalign
15
+ from pyxllib.prog.newbie import human_readable_number
15
16
 
16
17
  __tictoc = """
17
18
  基于 pytictoc 代码,做了些自定义扩展
@@ -40,13 +41,15 @@ class TicToc:
40
41
  TicToc.elapsed #t.end - t.start; i.e., time elapsed from t.start when t.toc() or t.tocvalue() was last called
41
42
  """
42
43
 
43
- def __init__(self, title='', *, disable=False):
44
+ def __init__(self, title='', *, disable=False, min_display_seconds=None):
44
45
  """Create instance of TicToc class."""
45
46
  self.start = timeit.default_timer()
46
47
  self.end = float('nan')
47
48
  self.elapsed = float('nan')
48
49
  self.title = title
49
50
  self.disable = disable
51
+ # 只有达到这个时间,才会显示耗时
52
+ self.min_display_seconds = min_display_seconds
50
53
 
51
54
  def tic(self):
52
55
  """Start the timer."""
@@ -64,7 +67,7 @@ class TicToc:
64
67
  self.elapsed = self.end - self.start
65
68
  if not self.disable:
66
69
  # print(f'{self.title} {msg} {self.elapsed:.3f} 秒.')
67
- print(f'{self.title} {msg} elapsed {format_timespan(self.elapsed)}.')
70
+ print(f'{self.title} {msg} elapsed {human_readable_number(self.elapsed, "秒")}.')
68
71
  if restart:
69
72
  self.start = timeit.default_timer()
70
73
 
@@ -84,14 +87,14 @@ class TicToc:
84
87
  @staticmethod
85
88
  def process_time(msg='time.process_time():'):
86
89
  """计算从python程序启动到目前为止总用时"""
87
- print(f'{msg} {format_timespan(time.process_time())}.')
90
+ print(f'{msg} {human_readable_number(time.process_time(), "秒")}.')
88
91
 
89
92
  def __enter__(self):
90
93
  """Start the timer when using TicToc in a context manager."""
91
94
  from pyxllib.prog.specialist import get_xllog
92
95
 
93
96
  if self.title == '__main__' and not self.disable:
94
- get_xllog().info(f'time.process_time(): {format_timespan(time.process_time())}.')
97
+ get_xllog().info(f'time.process_time(): {human_readable_number(time.process_time(), "秒")}.')
95
98
  self.start = timeit.default_timer()
96
99
 
97
100
  def __exit__(self, exc_type, exc_val, exc_tb):
@@ -102,10 +105,10 @@ class TicToc:
102
105
  xllog = get_xllog()
103
106
 
104
107
  if exc_tb is None:
105
- if not self.disable:
106
- xllog.info(f'{self.title} finished in {format_timespan(elapsed)}.')
108
+ if not self.disable and (self.min_display_seconds is None or elapsed >= self.min_display_seconds):
109
+ xllog.info(f'{self.title} finished in {human_readable_number(elapsed, "秒")}.')
107
110
  else:
108
- xllog.info(f'{self.title} interrupt in {format_timespan(elapsed)},')
111
+ xllog.info(f'{self.title} interrupt in {human_readable_number(elapsed, "秒")},')
109
112
 
110
113
 
111
114
  __timer = """
@@ -69,7 +69,10 @@ def get_charclass_num(content):
69
69
 
70
70
 
71
71
  def get_charclass_rate(content, round_digits=4):
72
- """ 检查字符类型分布数量 """
72
+ """ 检查字符类型分布数量
73
+
74
+ :param str content: 文本内容
75
+ """
73
76
  ct = get_charclass_num(content)
74
77
 
75
78
  # 这一类权重要翻倍
@@ -93,6 +96,8 @@ def check_language_from_counter(ct):
93
96
  这个比例最早是给表格设计的,表格很可能表头是中文,中间都是英文、数字数据,此时仍然归为中文
94
97
  但如果是一般性的文档,可能要提高中文的比例,才能视为中文文档
95
98
  """
99
+ ct['常用汉字'] = ct.get('常用汉字', 0)
100
+ ct['偏僻汉字'] = ct.get('偏僻汉字', 0)
96
101
 
97
102
  if '繁体汉字' in ct:
98
103
  if safe_div(ct['繁体汉字'], ct['常用汉字']) > 0.1:
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: pyxllib
3
- Version: 0.3.117
3
+ Version: 0.3.119
4
4
  Summary: 厦门理工模式识别团队通用python代码工具库
5
5
  Home-page: https://github.com/XLPRUtils/pyxllib
6
6
  Author: code4101
@@ -21,29 +21,28 @@ Jinja2
21
21
  pandas>=0.23.4
22
22
 
23
23
  [xlai]
24
- pynvml
25
- opsdroid-get-image-size
24
+ visdom
26
25
  opencv-python
27
26
  pillow
28
- xlcocotools
29
- visdom
27
+ pynvml
28
+ opsdroid-get-image-size
30
29
 
31
30
  [xlall]
32
- flask-cors
33
- html2text
34
- ujson
31
+ flask-restful
35
32
  flask-wtf
36
- sentencepiece
37
- flask-jwt-extended
38
- flask
39
- opsdroid-get-image-size
40
33
  opencv-python
41
- flask-restful
34
+ flask
35
+ flask-jwt-extended
36
+ xlrd
42
37
  pillow
43
38
  zhconv
44
- xlrd
39
+ ujson
40
+ flask-cors
41
+ sentencepiece
42
+ html2text
43
+ opsdroid-get-image-size
45
44
 
46
45
  [xlcv]
47
46
  pillow
48
- opsdroid-get-image-size
49
47
  opencv-python
48
+ opsdroid-get-image-size
@@ -22,8 +22,8 @@ opencv-python
22
22
  xlai = """
23
23
  pynvml
24
24
  visdom
25
- xlcocotools
26
25
  """
26
+ # xlcocotools
27
27
  # fvcore
28
28
 
29
29
  # 全量的依赖,自用
@@ -39,12 +39,13 @@ ujson
39
39
  html2text
40
40
  flask-jwt-extended
41
41
  """
42
+ # pywin32
42
43
 
43
44
  _dir = Path(__file__).parent
44
45
 
45
46
  setup(
46
47
  name='pyxllib', # pip 安装时用的名字
47
- version='0.3.117', # 当前版本,每次更新上传到pypi都需要修改; 第4位版本号一般是修紧急bug
48
+ version='0.3.119', # 当前版本,每次更新上传到pypi都需要修改; 第4位版本号一般是修紧急bug
48
49
  author='code4101',
49
50
  author_email='877362867@qq.com',
50
51
  url='https://github.com/XLPRUtils/pyxllib',
File without changes
File without changes
File without changes
File without changes
File without changes