鱼C论坛

 找回密码
 立即注册
查看: 1431|回复: 5

[已解决]两个链接怎么For循环

[复制链接]
发表于 2021-8-11 15:45:53 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
如何下代码,原来只去一个链接的内容,现在增加了一个链接,该如何写?红色为增加的链接。

import requests
from bs4 import BeautifulSoup
from openpyxl import Workbook
wb = Workbook()
ws = wb.active
ws['A1'] = "IP地址"
ws['B1'] = "总数"
n = 2
ip1 = ['192.168.3.12','192.168.55.20','192.168.3.18','192.168.70.18','192.168.3.15','192.168.70.20','192.168.70.24']
for i in ip1:
    url1 = "http://" + i + "/web/guest/cn/websys/status/getUnificationCounter.cgi"
    url3 = "http://" + i + "/web/guest/cn/websys/status/configuration.cgi"
    req = requests.get(url1)
    html = req.text
    bs = BeautifulSoup(html,"html.parser")
    trs = bs.select('tr.staticProp')[1].get_text()
    r = str(n)
    n = n + 1
    ws['a' + r] = i
    ws['b' + r] = i
    ws['c' + r] = trs[3:]
wb.save("C:\\New folder\\11.xlsx")
最佳答案
2021-8-12 13:25:42
Vastsea 发表于 2021-8-12 11:36
对不住,想自己写,不想一粘了之。还是搞错了。

两个链接取的位置不同,该怎么处理?

  1. import requests
  2. from bs4 import BeautifulSoup
  3. from openpyxl import Workbook

  4. wb = Workbook()
  5. ws = wb.active
  6. ws['A1'] = "IP地址"
  7. ws['B1'] = "总数"
  8. n = 2
  9. ips = ['192.168.3.12', '192.168.55.20', '192.168.3.18', '192.168.70.18', '192.168.3.15', '192.168.70.20',
  10.        '192.168.70.24']
  11. urls = [f"http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
  12.         f"http://%s/web/guest/cn/websys/status/configuration.cgi"]
  13. for i in ips:
  14.     for x, url in enumerate(urls):
  15.         req = requests.get(url % i)
  16.         html = req.text
  17.         bs = BeautifulSoup(html, "html.parser")
  18.         if x:
  19.             trs = bs.select('tr.staticProp')[17].get_text()
  20.         else:
  21.             trs = bs.select('tr.staticProp')[1].get_text()
  22.         r = str(n)
  23.         n = n + 1
  24.         ws['a' + r] = i
  25.         ws['b' + r] = i
  26.         ws['c' + r] = trs[3:]
  27. wb.save("C:\\New folder\\11.xlsx")
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-12 08:05:35 | 显示全部楼层
本帖最后由 suchocolate 于 2021-8-12 08:11 编辑
  1. import requests
  2. from bs4 import BeautifulSoup
  3. from openpyxl import Workbook

  4. wb = Workbook()
  5. ws = wb.active
  6. ws['A1'] = "IP地址"
  7. ws['B1'] = "总数"
  8. n = 2
  9. ips = ['192.168.3.12', '192.168.55.20', '192.168.3.18', '192.168.70.18', '192.168.3.15', '192.168.70.20',
  10.        '192.168.70.24']

  11. urls = ["http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
  12.         "http://%s/web/guest/cn/websys/status/configuration.cgi"]
  13. for i in ips:
  14.     for url in urls:
  15.         req = requests.get(url % i)
  16.         html = req.text
  17.         bs = BeautifulSoup(html, "html.parser")
  18.         trs = bs.select('tr.staticProp')[1].get_text()
  19.         r = str(n)
  20.         n = n + 1
  21.         ws['a' + r] = i
  22.         ws['b' + r] = i
  23.         ws['c' + r] = trs[3:]
  24. wb.save("C:\\New folder\\11.xlsx")
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-8-12 10:50:36 | 显示全部楼层

非常感谢。运行时给出如下错误。
  1. ---------------------------------------------------------------------------
  2. TypeError                                 Traceback (most recent call last)
  3. <ipython-input-3-5932eff03bb4> in <module>
  4.       6 for i in ip1:
  5.       7     for url in urls:
  6. ----> 8         req = requests.get(urls % i)
  7.       9         html = req.text
  8.      10         bs = BeautifulSoup(html,"html.parser")

  9. TypeError: unsupported operand type(s) for %: 'list' and 'str'
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-12 11:06:53 | 显示全部楼层
Vastsea 发表于 2021-8-12 10:50
非常感谢。运行时给出如下错误。

req = requests.get(url % i)
我写的是url,你写的urls,仔细核对。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-8-12 11:36:18 | 显示全部楼层
本帖最后由 Vastsea 于 2021-8-12 11:51 编辑
suchocolate 发表于 2021-8-12 11:06
req = requests.get(url % i)
我写的是url,你写的urls,仔细核对。


对不住,想自己写,不想一粘了之。还是搞错了。

两个链接取的位置不同,该怎么处理?

第一个链接

bs.select('tr.staticProp')[1].get_text()

第二个链接

bs.select('tr.staticProp')[17].get_text()
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-8-12 13:25:42 | 显示全部楼层    本楼为最佳答案   
Vastsea 发表于 2021-8-12 11:36
对不住,想自己写,不想一粘了之。还是搞错了。

两个链接取的位置不同,该怎么处理?

  1. import requests
  2. from bs4 import BeautifulSoup
  3. from openpyxl import Workbook

  4. wb = Workbook()
  5. ws = wb.active
  6. ws['A1'] = "IP地址"
  7. ws['B1'] = "总数"
  8. n = 2
  9. ips = ['192.168.3.12', '192.168.55.20', '192.168.3.18', '192.168.70.18', '192.168.3.15', '192.168.70.20',
  10.        '192.168.70.24']
  11. urls = [f"http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
  12.         f"http://%s/web/guest/cn/websys/status/configuration.cgi"]
  13. for i in ips:
  14.     for x, url in enumerate(urls):
  15.         req = requests.get(url % i)
  16.         html = req.text
  17.         bs = BeautifulSoup(html, "html.parser")
  18.         if x:
  19.             trs = bs.select('tr.staticProp')[17].get_text()
  20.         else:
  21.             trs = bs.select('tr.staticProp')[1].get_text()
  22.         r = str(n)
  23.         n = n + 1
  24.         ws['a' + r] = i
  25.         ws['b' + r] = i
  26.         ws['c' + r] = trs[3:]
  27. wb.save("C:\\New folder\\11.xlsx")
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-20 06:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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