51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

手机号码,快捷登录

查看: 1349|回复: 2
打印 上一主题 下一主题

python使用selenium时程序卡死

[复制链接]
  • TA的每日心情
    无聊
    4 天前
  • 签到天数: 530 天

    连续签到: 2 天

    [LV.9]测试副司令

    跳转到指定楼层
    1#
    发表于 2022-1-19 09:36:59 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    1测试积点
    问题遇到的现象和发生背景

    python使用selenium时程序卡死,既不报错也没有继续运行,ctrl+c也无法中断,代码中略去了使用PIL在图片上作图的部分,请问是电脑问题还是代码设计问题。

    1. from selenium import webdriver
    2. import time
    3. from PIL import Image
    4. from PIL import ImageDraw
    5. import datetime
    6. import requests
    7. import numpy as np

    8. def scprt():
    9.     chrome_driver = 'd:/radar_prt/chromedriver.exe'
    10.     options = webdriver.ChromeOptions()
    11.     options.add_argument('--headless')
    12.     options.add_argument('window-size=1920x1080')
    13.     driver = webdriver.Chrome(executable_path = chrome_driver, options = options)
    14.     driver.maximize_window()
    15.     driver.get('https://smart.zj121.com/radarNew/index.html')
    16.     driver.execute_script("map.setView({lat:28.6,lng:120.092}, 8.4)")
    17.     time.sleep(2)
    18.     driver.get_screenshot_as_file("d:/radar_prt/radar_or.png")
    19.     driver.quit()

    20. scprt()
    21. print('开始运行....')
    22. requests.adapters.DEFAULT_RETRIES = 5 # 增加重连次数
    23. s = requests.session()
    24. s.keep_alive = False # 关闭多余连接
    25. r = s.get('https://www.zj121.com/list/oss/res?key=zjqxfwzx-data/other/radar_HREF/&_=1642157916696').text
    26. rx = r.split(',', 200)
    27. first_rx = rx[199]
    28. while True:
    29.     try :
    30.         requests.adapters.DEFAULT_RETRIES = 5 # 增加重连次数
    31.         s = requests.session()
    32.         s.keep_alive = False # 关闭多余连接
    33.     except BaseException:
    34.             time.sleep(10)
    35.     else:
    36.         r = s.get('https://www.zj121.com/list/oss/res?key=zjqxfwzx-data/other/radar_HREF/&_=1642157916696').text
    37.         rx = r.split(',', 200)
    38.         daily_rx = rx[199]
    39.         nt = datetime.datetime.now().strftime('%H:%M:%S')
    40.         print(nt + ' 监测雷达更新中....')
    41.         if first_rx != daily_rx:
    42.             first_rx = daily_rx
    43.             scprt()
    44.             print(nt + ' 雷达已经更新....')
    45.         time.sleep(np.random.randint(32, 52))
    46.         
    复制代码


    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    2 小时前
  • 签到天数: 1522 天

    连续签到: 1 天

    [LV.Master]测试大本营

    2#
    发表于 2022-1-20 11:04:37 | 只看该作者
    是否有隐式等待
    回复

    使用道具 举报

  • TA的每日心情
    奋斗
    5 小时前
  • 签到天数: 2819 天

    连续签到: 1 天

    [LV.Master]测试大本营

    3#
    发表于 2022-1-20 17:07:59 | 只看该作者
    单步调试试试
    回复

    使用道具 举报

    本版积分规则

    关闭

    站长推荐上一条 /1 下一条

    小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

    GMT+8, 2024-11-25 12:29 , Processed in 0.063805 second(s), 24 queries .

    Powered by Discuz! X3.2

    © 2001-2024 Comsenz Inc.

    快速回复 返回顶部 返回列表