qrpa 1.0.86__py3-none-any.whl → 1.0.87__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.

Potentially problematic release.


This version of qrpa might be problematic. Click here for more details.

qrpa/shein_lib.py CHANGED
@@ -31,13 +31,19 @@ class SheinLib:
31
31
  def deal_auth(self):
32
32
  web_page = self.web_page
33
33
 
34
- # 等待页面稳定
34
+ # 等待页面稳定并收集诊断信息
35
35
  try:
36
- web_page.wait_for_load_state("networkidle", timeout=10000)
36
+ log(f"当前页面URL: {web_page.url}, 标题: {web_page.title()}", self.store_username, self.store_name)
37
+ web_page.wait_for_load_state("domcontentloaded", timeout=5000)
38
+ log("页面DOM加载完成", self.store_username, self.store_name)
37
39
  except Exception as e:
38
- log(f"等待页面稳定超时: {e}", self.store_username, self.store_name)
40
+ log(f"等待页面DOM加载超时: {e}, URL: {web_page.url}", self.store_username, self.store_name)
41
+ try:
42
+ log(f"页面状态检查 - 标题: {web_page.title()}, URL: {web_page.url}", self.store_username, self.store_name)
43
+ except Exception as check_error:
44
+ log(f"页面状态检查失败: {check_error}", self.store_username, self.store_name)
39
45
 
40
- web_page.wait_for_timeout(2000)
46
+ web_page.wait_for_timeout(3000)
41
47
 
42
48
  # 定义最大重试次数
43
49
  MAX_RETRIES = 5
@@ -53,6 +59,13 @@ class SheinLib:
53
59
  retries += 1
54
60
 
55
61
  while not web_page.locator('//div[contains(text(),"商家后台")]').nth(1).is_visible():
62
+
63
+ try:
64
+ current_url = web_page.url
65
+ current_title = web_page.title()
66
+ log(f"循环检查 - URL: {current_url}, 标题: {current_title}", self.store_username, self.store_name)
67
+ except Exception as status_error:
68
+ log(f"获取页面状态失败: {status_error}", self.store_username, self.store_name)
56
69
 
57
70
  if web_page.locator('xpath=//div[@id="container" and @alita-name="gmpsso"]//button[@type="button" and @id]').nth(0).is_visible():
58
71
  if 'https://sso.geiwohuo.com/#/home' not in web_page.url:
@@ -153,23 +166,31 @@ class SheinLib:
153
166
  except Exception as e:
154
167
  log(f"错误发生: {e}, 重试中...({self.store_username}, {self.store_name})")
155
168
  log(traceback.format_exc())
156
- if 'crashed' in str(e):
169
+
170
+ # 收集崩溃时的详细信息
171
+ try:
172
+ crash_url = web_page.url
173
+ crash_title = web_page.title()
174
+ log(f"崩溃时页面信息 - URL: {crash_url}, 标题: {crash_title}", self.store_username, self.store_name)
175
+
176
+ # 尝试截图保存崩溃现场
157
177
  try:
158
- log("检测到页面崩溃,尝试重建页面", self.store_username, self.store_name)
159
- context = web_page.context
160
- web_page.close()
161
- web_page = context.new_page()
162
- self.web_page = web_page
163
- web_page.goto('https://sso.geiwohuo.com/#/home', wait_until='domcontentloaded', timeout=15000)
164
- web_page.wait_for_timeout(3000)
165
- log("页面重建成功", self.store_username, self.store_name)
166
- except Exception as recovery_error:
167
- log(f"页面重建失败: {recovery_error}", self.store_username, self.store_name)
168
- try:
169
- web_page.reload(wait_until='domcontentloaded', timeout=10000)
170
- web_page.wait_for_timeout(3000)
171
- except:
172
- web_page.wait_for_timeout(5000)
178
+ screenshot_path = f"crash_screenshot_{self.store_username}_{int(time.time())}.png"
179
+ web_page.screenshot(path=screenshot_path)
180
+ log(f"已保存崩溃截图: {screenshot_path}", self.store_username, self.store_name)
181
+ except:
182
+ log("无法截取崩溃时的页面截图", self.store_username, self.store_name)
183
+
184
+ except:
185
+ log("无法获取崩溃时的页面信息", self.store_username, self.store_name)
186
+
187
+ # 检查是否是内存相关崩溃
188
+ if any(keyword in str(e).lower() for keyword in ['memory', 'out of memory', 'oom']):
189
+ log("检测到内存相关崩溃", self.store_username, self.store_name)
190
+
191
+ if 'crashed' in str(e) or 'Target' in str(e):
192
+ log("检测到页面或目标崩溃,直接退出当前循环", self.store_username, self.store_name)
193
+ raise e
173
194
  retries += 1
174
195
  if retries >= MAX_RETRIES:
175
196
  log(f"达到最大重试次数,停止尝试({self.store_username}, {self.store_name})")
qrpa/shein_ziniao.py CHANGED
@@ -258,7 +258,7 @@ class ZiniaoBrowser:
258
258
  """打开启动页面并执行业务逻辑"""
259
259
  page = browser_context.pages[0]
260
260
  page.goto(launcher_page)
261
- page.wait_for_timeout(6000)
261
+ page.wait_for_timeout(3000)
262
262
 
263
263
  run_func(page, store_username, store_name, task_key)
264
264
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: qrpa
3
- Version: 1.0.86
3
+ Version: 1.0.87
4
4
  Summary: qsir's rpa library
5
5
  Author: QSir
6
6
  Author-email: QSir <1171725650@qq.com>
@@ -11,10 +11,10 @@ qrpa/fun_web.py,sha256=Ep2ddMwJix_KNpCiHEjSo7tWu-g55Nlu1QtOXJf6iZw,6531
11
11
  qrpa/fun_win.py,sha256=-LnTeocdTt72NVH6VgLdpAT9_C5oV9okeudXG6CftMA,8034
12
12
  qrpa/shein_daily_report_model.py,sha256=H8oZmIN5Pyqe306W1_xuz87lOqLQ_LI5RjXbaxDkIzE,12589
13
13
  qrpa/shein_excel.py,sha256=1F9QMMsaihDfwr0ajSSQdXksBCjuKSPwMynfP7Jlkso,124825
14
- qrpa/shein_lib.py,sha256=h14_jc2a1Y5vgA7jxuCWwvZL_02P81LZ7NW11LPjiYU,129299
14
+ qrpa/shein_lib.py,sha256=y8xJWo6criTHGtl_RyZ8_hKj7_HpiGTn-OWFE9RadPU,130714
15
15
  qrpa/shein_mysql.py,sha256=Sgz6U0_3f4cT5zPf1Ht1OjvSFhrVPLkMxt91NV-ZPCM,3005
16
16
  qrpa/shein_sqlite.py,sha256=ZQwD0Gz81q9WY7tY2HMEYvSF9r3N_G_Aur3bYfST9WY,5707
17
- qrpa/shein_ziniao.py,sha256=3PvoRK-J81q5vhNXdhJ_OODExXPrPfJzTgYBH1S4rxM,18703
17
+ qrpa/shein_ziniao.py,sha256=hjEgK5gNWytAkvTvJQKEy3A3L-R0sArgnSBk85m41ow,18703
18
18
  qrpa/temu_chrome.py,sha256=CbtFy1QPan9xJdJcNZj-EsVGhUvv3ZTEPVDEA4-im40,2803
19
19
  qrpa/temu_excel.py,sha256=2hGw76YWzkTZGyFCuuUAab4oHptYX9a6U6yjpNsL7FE,6990
20
20
  qrpa/temu_lib.py,sha256=hYB59zsLS3m3NTic_duTwPMOTSxlHyQVa8OhHnHm-1g,7199
@@ -24,7 +24,7 @@ qrpa/wxwork.py,sha256=gIytG19DZ5g7Tsl0-W3EbjfSnpIqZw-ua24gcB78YEg,11264
24
24
  qrpa/mysql_module/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
25
25
  qrpa/mysql_module/shein_product_model.py,sha256=qViI_Ik3SkXXxqJ1nXjimvfB_a5uiwW9RXL0fOreBao,18880
26
26
  qrpa/mysql_module/shein_return_order_model.py,sha256=Zt-bGOH_kCDbakW7uaTmqqo_qTT8v424yidcYSfWvWM,26562
27
- qrpa-1.0.86.dist-info/METADATA,sha256=8SKuj7fmuQC1htBIZ8_ZyPo0SlB7Ez4ShktnoXCZy2k,231
28
- qrpa-1.0.86.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
29
- qrpa-1.0.86.dist-info/top_level.txt,sha256=F6T5igi0fhXDucPPUbmmSC0qFCDEsH5eVijfVF48OFU,5
30
- qrpa-1.0.86.dist-info/RECORD,,
27
+ qrpa-1.0.87.dist-info/METADATA,sha256=yhgh3bYUgoI0juVda-txdOQ3Nmwj1OllNTta0X1kjYg,231
28
+ qrpa-1.0.87.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
29
+ qrpa-1.0.87.dist-info/top_level.txt,sha256=F6T5igi0fhXDucPPUbmmSC0qFCDEsH5eVijfVF48OFU,5
30
+ qrpa-1.0.87.dist-info/RECORD,,
File without changes