pyxllib 0.0.43__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 (186) hide show
  1. pyxllib/__init__.py +9 -2
  2. pyxllib/algo/__init__.py +8 -0
  3. pyxllib/algo/disjoint.py +54 -0
  4. pyxllib/algo/geo.py +541 -0
  5. pyxllib/{util/mathlib.py → algo/intervals.py} +172 -36
  6. pyxllib/algo/matcher.py +389 -0
  7. pyxllib/algo/newbie.py +166 -0
  8. pyxllib/algo/pupil.py +629 -0
  9. pyxllib/algo/shapelylib.py +67 -0
  10. pyxllib/algo/specialist.py +241 -0
  11. pyxllib/algo/stat.py +494 -0
  12. pyxllib/algo/treelib.py +149 -0
  13. pyxllib/algo/unitlib.py +66 -0
  14. pyxllib/autogui/__init__.py +5 -0
  15. pyxllib/autogui/activewin.py +246 -0
  16. pyxllib/autogui/all.py +9 -0
  17. pyxllib/autogui/autogui.py +852 -0
  18. pyxllib/autogui/uiautolib.py +362 -0
  19. pyxllib/autogui/virtualkey.py +102 -0
  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 +1 -11
  24. pyxllib/cv/expert.py +267 -0
  25. pyxllib/cv/{imlib.py → imfile.py} +18 -83
  26. pyxllib/cv/imhash.py +39 -0
  27. pyxllib/cv/pupil.py +9 -0
  28. pyxllib/cv/rgbfmt.py +1525 -0
  29. pyxllib/cv/slidercaptcha.py +137 -0
  30. pyxllib/cv/trackbartools.py +163 -49
  31. pyxllib/cv/xlcvlib.py +1040 -0
  32. pyxllib/cv/xlpillib.py +423 -0
  33. pyxllib/data/__init__.py +0 -0
  34. pyxllib/data/echarts.py +240 -0
  35. pyxllib/data/jsonlib.py +89 -0
  36. pyxllib/{util/oss2_.py → data/oss.py} +11 -9
  37. pyxllib/data/pglib.py +1127 -0
  38. pyxllib/data/sqlite.py +568 -0
  39. pyxllib/{util → data}/sqllib.py +13 -31
  40. pyxllib/ext/JLineViewer.py +505 -0
  41. pyxllib/ext/__init__.py +6 -0
  42. pyxllib/{util → ext}/demolib.py +119 -35
  43. pyxllib/ext/drissionlib.py +277 -0
  44. pyxllib/ext/kq5034lib.py +12 -0
  45. pyxllib/{util/main.py → ext/old.py} +122 -284
  46. pyxllib/ext/qt.py +449 -0
  47. pyxllib/ext/robustprocfile.py +497 -0
  48. pyxllib/ext/seleniumlib.py +76 -0
  49. pyxllib/{util/tklib.py → ext/tk.py} +10 -11
  50. pyxllib/ext/unixlib.py +827 -0
  51. pyxllib/ext/utools.py +351 -0
  52. pyxllib/{util/webhooklib.py → ext/webhook.py} +45 -17
  53. pyxllib/ext/win32lib.py +40 -0
  54. pyxllib/ext/wjxlib.py +88 -0
  55. pyxllib/ext/wpsapi.py +124 -0
  56. pyxllib/ext/xlwork.py +9 -0
  57. pyxllib/ext/yuquelib.py +1105 -0
  58. pyxllib/file/__init__.py +17 -0
  59. pyxllib/file/docxlib.py +761 -0
  60. pyxllib/{util → file}/gitlib.py +40 -27
  61. pyxllib/file/libreoffice.py +165 -0
  62. pyxllib/file/movielib.py +148 -0
  63. pyxllib/file/newbie.py +10 -0
  64. pyxllib/file/onenotelib.py +1469 -0
  65. pyxllib/file/packlib/__init__.py +330 -0
  66. pyxllib/{util → file/packlib}/zipfile.py +598 -195
  67. pyxllib/file/pdflib.py +426 -0
  68. pyxllib/file/pupil.py +185 -0
  69. pyxllib/file/specialist/__init__.py +685 -0
  70. pyxllib/{basic/_5_dirlib.py → file/specialist/dirlib.py} +364 -93
  71. pyxllib/file/specialist/download.py +193 -0
  72. pyxllib/file/specialist/filelib.py +2829 -0
  73. pyxllib/file/xlsxlib.py +3131 -0
  74. pyxllib/file/xlsyncfile.py +341 -0
  75. pyxllib/prog/__init__.py +5 -0
  76. pyxllib/prog/cachetools.py +64 -0
  77. pyxllib/prog/deprecatedlib.py +233 -0
  78. pyxllib/prog/filelock.py +42 -0
  79. pyxllib/prog/ipyexec.py +253 -0
  80. pyxllib/prog/multiprogs.py +940 -0
  81. pyxllib/prog/newbie.py +451 -0
  82. pyxllib/prog/pupil.py +1197 -0
  83. pyxllib/{sitepackages.py → prog/sitepackages.py} +5 -3
  84. pyxllib/prog/specialist/__init__.py +391 -0
  85. pyxllib/prog/specialist/bc.py +203 -0
  86. pyxllib/prog/specialist/browser.py +497 -0
  87. pyxllib/prog/specialist/common.py +347 -0
  88. pyxllib/prog/specialist/datetime.py +199 -0
  89. pyxllib/prog/specialist/tictoc.py +240 -0
  90. pyxllib/prog/specialist/xllog.py +180 -0
  91. pyxllib/prog/xlosenv.py +108 -0
  92. pyxllib/stdlib/__init__.py +17 -0
  93. pyxllib/{util → stdlib}/tablepyxl/__init__.py +1 -3
  94. pyxllib/{util → stdlib}/tablepyxl/style.py +1 -1
  95. pyxllib/{util → stdlib}/tablepyxl/tablepyxl.py +2 -4
  96. pyxllib/text/__init__.py +8 -0
  97. pyxllib/text/ahocorasick.py +39 -0
  98. pyxllib/text/airscript.js +744 -0
  99. pyxllib/text/charclasslib.py +121 -0
  100. pyxllib/text/jiebalib.py +267 -0
  101. pyxllib/text/jinjalib.py +32 -0
  102. pyxllib/text/jsa_ai_prompt.md +271 -0
  103. pyxllib/text/jscode.py +922 -0
  104. pyxllib/text/latex/__init__.py +158 -0
  105. pyxllib/text/levenshtein.py +303 -0
  106. pyxllib/text/nestenv.py +1215 -0
  107. pyxllib/text/newbie.py +300 -0
  108. pyxllib/text/pupil/__init__.py +8 -0
  109. pyxllib/text/pupil/common.py +1121 -0
  110. pyxllib/text/pupil/xlalign.py +326 -0
  111. pyxllib/text/pycode.py +47 -0
  112. pyxllib/text/specialist/__init__.py +8 -0
  113. pyxllib/text/specialist/common.py +112 -0
  114. pyxllib/text/specialist/ptag.py +186 -0
  115. pyxllib/text/spellchecker.py +172 -0
  116. pyxllib/text/templates/echart_base.html +11 -0
  117. pyxllib/text/templates/highlight_code.html +17 -0
  118. pyxllib/text/templates/latex_editor.html +103 -0
  119. pyxllib/text/vbacode.py +17 -0
  120. pyxllib/text/xmllib.py +747 -0
  121. pyxllib/xl.py +39 -0
  122. pyxllib/xlcv.py +17 -0
  123. pyxllib-0.3.197.dist-info/METADATA +48 -0
  124. pyxllib-0.3.197.dist-info/RECORD +126 -0
  125. {pyxllib-0.0.43.dist-info → pyxllib-0.3.197.dist-info}/WHEEL +4 -5
  126. pyxllib/basic/_1_strlib.py +0 -945
  127. pyxllib/basic/_2_timelib.py +0 -488
  128. pyxllib/basic/_3_pathlib.py +0 -916
  129. pyxllib/basic/_4_loglib.py +0 -419
  130. pyxllib/basic/__init__.py +0 -54
  131. pyxllib/basic/arrow_.py +0 -250
  132. pyxllib/basic/chardet_.py +0 -66
  133. pyxllib/basic/dirlib.py +0 -529
  134. pyxllib/basic/dprint.py +0 -202
  135. pyxllib/basic/extension.py +0 -12
  136. pyxllib/basic/judge.py +0 -31
  137. pyxllib/basic/log.py +0 -204
  138. pyxllib/basic/pathlib_.py +0 -705
  139. pyxllib/basic/pytictoc.py +0 -102
  140. pyxllib/basic/qiniu_.py +0 -61
  141. pyxllib/basic/strlib.py +0 -761
  142. pyxllib/basic/timer.py +0 -132
  143. pyxllib/cv/cv.py +0 -834
  144. pyxllib/cv/cvlib/_1_geo.py +0 -543
  145. pyxllib/cv/cvlib/_2_cvprcs.py +0 -309
  146. pyxllib/cv/cvlib/_2_imgproc.py +0 -594
  147. pyxllib/cv/cvlib/_3_pilprcs.py +0 -80
  148. pyxllib/cv/cvlib/_4_cvimg.py +0 -211
  149. pyxllib/cv/cvlib/__init__.py +0 -10
  150. pyxllib/cv/debugtools.py +0 -82
  151. pyxllib/cv/fitz_.py +0 -300
  152. pyxllib/cv/installer.py +0 -42
  153. pyxllib/debug/_0_installer.py +0 -38
  154. pyxllib/debug/_1_typelib.py +0 -277
  155. pyxllib/debug/_2_chrome.py +0 -198
  156. pyxllib/debug/_3_showdir.py +0 -161
  157. pyxllib/debug/_4_bcompare.py +0 -140
  158. pyxllib/debug/__init__.py +0 -49
  159. pyxllib/debug/bcompare.py +0 -132
  160. pyxllib/debug/chrome.py +0 -198
  161. pyxllib/debug/installer.py +0 -38
  162. pyxllib/debug/showdir.py +0 -158
  163. pyxllib/debug/typelib.py +0 -278
  164. pyxllib/image/__init__.py +0 -12
  165. pyxllib/torch/__init__.py +0 -20
  166. pyxllib/torch/modellib.py +0 -37
  167. pyxllib/torch/trainlib.py +0 -344
  168. pyxllib/util/__init__.py +0 -20
  169. pyxllib/util/aip_.py +0 -141
  170. pyxllib/util/casiadb.py +0 -59
  171. pyxllib/util/excellib.py +0 -495
  172. pyxllib/util/filelib.py +0 -612
  173. pyxllib/util/jsondata.py +0 -27
  174. pyxllib/util/jsondata2.py +0 -92
  175. pyxllib/util/labelmelib.py +0 -139
  176. pyxllib/util/onepy/__init__.py +0 -29
  177. pyxllib/util/onepy/onepy.py +0 -574
  178. pyxllib/util/onepy/onmanager.py +0 -170
  179. pyxllib/util/pyautogui_.py +0 -219
  180. pyxllib/util/textlib.py +0 -1305
  181. pyxllib/util/unorder.py +0 -22
  182. pyxllib/util/xmllib.py +0 -639
  183. pyxllib-0.0.43.dist-info/METADATA +0 -39
  184. pyxllib-0.0.43.dist-info/RECORD +0 -80
  185. pyxllib-0.0.43.dist-info/top_level.txt +0 -1
  186. {pyxllib-0.0.43.dist-info → pyxllib-0.3.197.dist-info/licenses}/LICENSE +0 -0
@@ -0,0 +1,66 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ # @Author : 陈坤泽
4
+ # @Email : 877362867@qq.com
5
+ # @Date : 2021/09/26 09:47
6
+
7
+ """ 单位功能库 """
8
+
9
+ from pyxllib.prog.pupil import check_install_package
10
+
11
+ check_install_package('pint')
12
+
13
+ import pint
14
+
15
+ import pandas as pd
16
+
17
+ from pyxllib.prog.newbie import xl_format_g
18
+ from pyxllib.prog.pupil import run_once
19
+
20
+
21
+ @run_once
22
+ def get_ureg():
23
+ """ 如果不想重复生成,可以用这个函数,只定义一个 """
24
+ ureg = pint.UnitRegistry()
25
+ return ureg
26
+
27
+
28
+ def compare_quantity(units, base_unit, scale=None):
29
+ """ 同一物理维度的数值量级大小对比
30
+
31
+ 比如一套天文长度、距离数据,对比它们之间的量级大小
32
+
33
+ :param List[str, str] units: 一组要对比的单位数值
34
+ 第1个str是描述,第2个str是数值和单位
35
+ :param base_unit: 基础单位值,比如长度是m,也可以用km等自己喜欢的基础单位值
36
+ :param scale: 对数值进行缩放
37
+ """
38
+ ureg = get_ureg()
39
+
40
+ # 统一到单位:米
41
+ for x in units:
42
+ x[1] = ureg(x[1]).to(base_unit)
43
+
44
+ # 从小到大排
45
+ units.sort(key=lambda x: x[1])
46
+
47
+ # 格式化输出r
48
+ unit_list = []
49
+ if scale:
50
+ columns = ['name', f'基础单位:{base_unit}', 'scale', '与上一项倍率']
51
+ else:
52
+ columns = ['name', f'基础单位:{base_unit}', 'scale', '与上一项倍率']
53
+ last_value = units[0][1]
54
+ for i, x in enumerate(units, start=1):
55
+ x = x.copy()
56
+ # x.append('{:.3g}'.format(round(float(x[1] / last_value), 2)))
57
+ if scale:
58
+ x.append(f'{x[1] * scale:.2e}')
59
+ x.append(xl_format_g(round(float(x[1] / last_value), 2)))
60
+ last_value = x[1]
61
+ x[1] = f'{x[1]:.2e}'
62
+ # print(f'{i:>4}', '\t'.join(x))
63
+ unit_list.append(x)
64
+
65
+ df = pd.DataFrame.from_records(unit_list, columns=columns)
66
+ return df
@@ -0,0 +1,5 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ # @Author : 陈坤泽
4
+ # @Email : 877362867@qq.com
5
+ # @Date : 2021/08/01 15:26
@@ -0,0 +1,246 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ # @Author : 陈坤泽
4
+ # @Email : 877362867@qq.com
5
+ # @Date : 2024/10/29
6
+
7
+ import platform
8
+ import sys
9
+ import time
10
+
11
+ import cv2
12
+ import psutil
13
+ import numpy as np
14
+
15
+ if sys.platform == 'win32':
16
+ import win32gui
17
+ import win32process
18
+ # from pywinauto import Desktop
19
+ import uiautomation
20
+
21
+ from pyxllib.prog.cachetools import xlcache
22
+ from pyxllib.cv.xlcvlib import CvImg
23
+ from pyxlpr.ai.clientlib import XlAiClient
24
+
25
+ # 根据平台扩展相应的类
26
+ if platform.system().lower() == "darwin":
27
+ from mss.darwin import MSS as OriginalMSS
28
+ elif platform.system().lower() == "linux":
29
+ from mss.linux import MSS as OriginalMSS
30
+ elif platform.system().lower() == "windows":
31
+ from mss.windows import MSS as OriginalMSS
32
+ else:
33
+ raise RuntimeError("Unsupported platform")
34
+
35
+
36
+ def adjust_monitors(monitors, scale_factor):
37
+ # 调整所有物理显示器的尺寸和位置
38
+ for i in range(1, len(monitors)):
39
+ monitors[i]['width'] = int(monitors[i]['width'] / scale_factor)
40
+ monitors[i]['height'] = int(monitors[i]['height'] / scale_factor)
41
+ monitors[i]['top'] = int(monitors[i]['top'] / scale_factor)
42
+ monitors[i]['left'] = int(monitors[i]['left'] / scale_factor)
43
+
44
+ # 计算虚拟桌面的边界
45
+ left_bound = min(monitor['left'] for monitor in monitors[1:])
46
+ top_bound = min(monitor['top'] for monitor in monitors[1:])
47
+ right_bound = max(monitor['left'] + monitor['width'] for monitor in monitors[1:])
48
+ bottom_bound = max(monitor['top'] + monitor['height'] for monitor in monitors[1:])
49
+
50
+ # 设置虚拟桌面的尺寸和位置
51
+ monitors[0]['width'] = right_bound - left_bound
52
+ monitors[0]['height'] = bottom_bound - top_bound
53
+ monitors[0]['top'] = top_bound
54
+ monitors[0]['left'] = left_bound
55
+
56
+ return monitors
57
+
58
+
59
+ class ActiveWindowCapture(OriginalMSS):
60
+ """
61
+ 基于`MSS`库的一个扩展,用于实现跨平台的多屏幕截图,并添加了以下独特功能:
62
+ 1. 实时窗口捕获:能够获取当前激活的窗口信息,并关联到对应的进程对象。
63
+ 这一特性使得该类在需要实时监控、分析特定应用窗口时尤为实用。
64
+ 2. 缓存机制:该类采用了缓存策略,通过`xlcache`装饰器缓存截取的屏幕和窗口数据,避免频繁重复捕获,提升性能。
65
+ 缓存机制同时确保在多窗口环境中,当前获取的窗口信息是实际的活动窗口,防止数据滞后或错位。
66
+ 3. 多屏幕拼接与坐标调整:支持多屏幕拼接功能,能够调整不同显示器的坐标和尺寸,以生成全屏拼接的截图画布。
67
+ 对于分辨率缩放和多屏偏移,也可以进行自适应调整。
68
+ 4. 标记窗口功能:在截屏时,可以选择性地标记当前激活窗口的位置,支持自定义标记的颜色、厚度和偏移量,便于在截图中直观地显示当前活跃窗口。
69
+
70
+ 适合需要频繁截图、实时监控活动窗口和对应进程的场景,尤其在多屏和分辨率适配方面提供了便捷的解决方案。
71
+ """
72
+
73
+ def __1_动态成员变量(self):
74
+ pass
75
+
76
+ def __init__(self, *, scale=1):
77
+ """
78
+ :param scale: 可适当兼容主屏幕做了缩放处理的情景,但太复杂的情况下也不一定对
79
+ """
80
+ super().__init__()
81
+ self.scale = scale
82
+
83
+ @xlcache(property=True)
84
+ def monitors2(self):
85
+ """ 修正后的各个屏幕坐标 """
86
+ monitors = self.monitors
87
+ if self.scale != 1:
88
+ monitors = adjust_monitors(monitors, self.scale)
89
+ return monitors
90
+
91
+ @xlcache(property=True)
92
+ def window(self):
93
+ """ 当前激活窗口 """
94
+ # 可以小等一会等到有效窗口
95
+ for i in range(4):
96
+ win = uiautomation.GetForegroundControl()
97
+ if win:
98
+ return win
99
+ else:
100
+ time.sleep(0.5)
101
+ return
102
+
103
+ @xlcache(property=True)
104
+ def process(self):
105
+ """ 当前激活窗口 """
106
+ hwnd = self.window.NativeWindowHandle
107
+ thread_id, process_id = win32process.GetWindowThreadProcessId(hwnd)
108
+ return psutil.Process(process_id)
109
+
110
+ @xlcache(property=True)
111
+ def xlapi(self):
112
+ return XlAiClient()
113
+
114
+ def __2_截图数据(self):
115
+ pass
116
+
117
+ @xlcache()
118
+ def _capture_single_monitor(self, order):
119
+ """ 缓存单个屏幕的截图 """
120
+ if order == 0:
121
+ # order=0时,拼接所有屏幕图像。虽然mss其实可以直接提供,但是这样就没有每个屏幕缓存的图片了,还是我自己处理一遍更好。
122
+
123
+ # 计算坐标偏移量,将所有坐标调整至非负
124
+ min_left = min(monitor['left'] for monitor in self.monitors2)
125
+ min_top = min(monitor['top'] for monitor in self.monitors2)
126
+
127
+ # 获取总画布大小(根据所有屏幕的范围计算)
128
+ max_right = max(monitor['left'] + monitor['width'] for monitor in self.monitors2)
129
+ max_bottom = max(monitor['top'] + monitor['height'] for monitor in self.monitors2)
130
+ canvas_width = max_right - min_left
131
+ canvas_height = max_bottom - min_top
132
+
133
+ # 使用numpy创建空白画布 (BGR格式)
134
+ img_canvas = np.zeros((canvas_height, canvas_width, 3), dtype=np.uint8)
135
+
136
+ # 获取并缓存每个子屏幕截图,按调整后的坐标拼接到总画布
137
+ for i in range(1, len(self.monitors2)):
138
+ monitor = self.monitors2[i]
139
+ single_img = self._capture_single_monitor(i) # 获取单屏截图 (cv2格式)
140
+ # 将子屏幕截图粘贴到总画布的指定位置,应用坐标偏移
141
+ x_offset = monitor['left'] - min_left
142
+ y_offset = monitor['top'] - min_top
143
+ img_canvas[y_offset:y_offset + single_img.shape[0],
144
+ x_offset:x_offset + single_img.shape[1]] = single_img
145
+
146
+ img_cv2 = img_canvas
147
+ else:
148
+ if order == -1:
149
+ # 截取当前活动窗口的截图
150
+ active_window = self.window
151
+ rect = active_window.BoundingRectangle
152
+ monitor = {
153
+ 'left': int(rect.left),
154
+ 'top': int(rect.top),
155
+ 'width': int(rect.right - rect.left),
156
+ 'height': int(rect.bottom - rect.top),
157
+ }
158
+ sct_img = self.grab(monitor)
159
+ else:
160
+ sct_img = self.grab(self.monitors2[order])
161
+
162
+ # 将截图的原始数据转换成numpy数组
163
+ img_np = np.frombuffer(sct_img.bgra, dtype=np.uint8)
164
+ img_np = img_np.reshape((sct_img.height, sct_img.width, 4)) # 高、宽、4通道
165
+ # 转换成BGR通道顺序
166
+ img_cv2 = cv2.cvtColor(img_np, cv2.COLOR_BGRA2BGR)
167
+
168
+ return img_cv2
169
+
170
+ def _mark_window_on_screenshot(self, screenshot, window_rect, order=0, mark_params=None):
171
+ """
172
+ 在截图中标记窗口,并根据 order 参数自动调整坐标偏移。
173
+
174
+ :param screenshot: 要标记的截图图像
175
+ :param window_rect: 当前激活窗口的原始坐标 (left, top, right, bottom)
176
+ :param order: 屏幕索引 (0 表示拼接所有屏幕,全图模式)
177
+ :param mark_params: 标记参数字典,包含 color, base, thickness 等
178
+ :return: 标记后的截图
179
+ """
180
+ # 1 设定默认标记参数,若传入 mark_params 则进行更新
181
+ default_params = {
182
+ "color": (0, 255, 0), # 默认绿色
183
+ "base": 10, # 默认缩进 10 像素
184
+ "thickness": 3 # 默认厚度 3 像素
185
+ }
186
+ mark_params = mark_params if isinstance(mark_params, dict) else None
187
+ if mark_params:
188
+ default_params.update(mark_params)
189
+
190
+ color = default_params["color"]
191
+ base = default_params["base"]
192
+ thickness = default_params["thickness"]
193
+
194
+ # 2 获取对应 order 的屏幕原点坐标进行偏差修正
195
+ if order == 0:
196
+ origin_x = self.monitors2[0]['left']
197
+ origin_y = self.monitors2[0]['top']
198
+ else:
199
+ origin_x = self.monitors2[order]['left']
200
+ origin_y = self.monitors2[order]['top']
201
+
202
+ # 计算相对于指定屏幕或全图的窗口坐标
203
+ adjusted_coords = (
204
+ int(window_rect.left) - origin_x,
205
+ int(window_rect.top) - origin_y,
206
+ int(window_rect.right) - origin_x,
207
+ int(window_rect.bottom) - origin_y,
208
+ )
209
+
210
+ # 3 绘制矩形标记
211
+ cv2.rectangle(
212
+ screenshot,
213
+ (adjusted_coords[0] + base, adjusted_coords[1] + base),
214
+ (adjusted_coords[2] - base, adjusted_coords[3] - base),
215
+ color, # 使用自定义颜色
216
+ thickness # 使用自定义厚度
217
+ )
218
+
219
+ return screenshot
220
+
221
+ @xlcache()
222
+ def screenshot(self, order=0, *, to_pil=False, mark_active_window=False):
223
+ """ 截屏
224
+
225
+ :param int order:
226
+ -1, 截取当前激活窗口
227
+ 0,默认值,截取全部屏幕
228
+ 1,截取第1个屏幕
229
+ 2,截取第2个屏幕
230
+ ...
231
+ :param to_pil: 是否转换成 PIL 格式
232
+ :param mark_active_window: 是否标记当前激活窗口,若为字典可设置颜色、厚度等参数
233
+ :return: np矩阵或PIL图片,取决于to_cv2参数
234
+ """
235
+ assert order < len(self.monitors), '屏幕下标越界'
236
+ img = self._capture_single_monitor(order) # 调用子函数处理所有屏幕拼接
237
+
238
+ # 若需要标记当前激活窗口
239
+ if mark_active_window:
240
+ img = self._mark_window_on_screenshot(img, self.window.BoundingRectangle, order,
241
+ mark_params=mark_active_window)
242
+
243
+ if to_pil:
244
+ img = CvImg.read(img).to_pil_image() # 转成pil矩阵格式
245
+
246
+ return img
pyxllib/autogui/all.py ADDED
@@ -0,0 +1,9 @@
1
+ #!/usr/bin/env python3
2
+ # -*- coding: utf-8 -*-
3
+ # @Author : 陈坤泽
4
+ # @Email : 877362867@qq.com
5
+ # @Date : 2024/10/29
6
+
7
+ from pyxllib.autogui.autogui import *
8
+ from pyxllib.autogui.virtualkey import *
9
+ from pyxllib.autogui.activewin import *