python - 使用计数器后,Python循环没有中断
问题描述
我在下面的代码末尾添加了一个计数器。但是,当代码继续运行超过 10 的计数器时,我将其设置为中断。无法弄清楚我做错了什么。
chromedriver='C:\\Users\\user\\Downloads\\chromedriver_win32\\chromedriver.exe'
options=webdriver.ChromeOptions()
options.add_argument('headless')
options.add_argument('window-size=1200x600')
browser=webdriver.Chrome(executable_path=chromedriver,chrome_options=options)
path='C:/Users/something.xlsx'
xls=pd.read_excel(path)
data=xls["companyname"].tolist()
data=[w.replace('" "','+') for w in data]
book=openpyxl.load_workbook(path)
sheet=book.active
try:
delete=book['Python Data']
book.remove(delete)
except Exception:
pass
book.create_sheet('Python Data')
ws1=book['Python Data']
book.save(path)
counter=0
while data:
for item in data:
browser.get('https://duckduckgo.com/?q='+item+'&t=h_')
results = browser.find_elements_by_id('links')
num_page_items = len(results)
for i in range(num_page_items):
mylist = results[i].text
row=len(ws1['A']) + 1
ws1.cell(row=1,column=1,value="Results")
ws1.cell(row=row,column=1,value=mylist)
book.save(path)
counter += 1
print(counter)
if counter==10:
break
解决方案
counter == 10
由于无限while data
语句,您的代码在到达后再次执行。请注意,这break
并没有逃避while
这里的陈述,它适用于for i in range(num_page_items)
.
请使用以下代码:
# notice lack of while data statement
for item in data:
browser.get('https://duckduckgo.com/?q='+item+'&t=h_')
results = browser.find_elements_by_id('links')
num_page_items = len(results)
for i in range(num_page_items):
mylist = results[i].text
row=len(ws1['A']) + 1
ws1.cell(row=1,column=1,value="Results")
ws1.cell(row=row,column=1,value=mylist)
book.save(path)
counter += 1
print(counter)
if counter==10:
break
推荐阅读
- google-cloud-platform - 谷歌云平台 SSH 错误代码 1006
- mysql - 使用 MySQL 表名填充 VBA 组合框
- python - 表单 URL 错误:未找到任何参数的“printReports”反向。已尝试 1 种模式
- mysql - mysql Workbench表数据导入向导解码问题
- arrays - 我应该如何在不同的组件中显示我的检查结果?
- java - 将加密脚本 AES/CBC/PKCS5PADDING Java 转换为 php
- spring-boot - 对于 Hazelcast sidecar 缓存模式,是否可以预期客户端会发现每个节点两次?
- python - 在一个目录中处理多个 python 项目的最佳方法?
- html - 一起创建倒置边框半径和 box-shadow
- qt - CGAL分类_插件错误