鱼C论坛

 找回密码
 立即注册
查看: 1208|回复: 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
对不住,想自己写,不想一粘了之。还是搞错了。

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

import requests
from bs4 import BeautifulSoup
from openpyxl import Workbook

wb = Workbook()
ws = wb.active
ws['A1'] = "IP地址"
ws['B1'] = "总数"
n = 2
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',
       '192.168.70.24']
urls = [f"http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
        f"http://%s/web/guest/cn/websys/status/configuration.cgi"]
for i in ips:
    for x, url in enumerate(urls):
        req = requests.get(url % i)
        html = req.text
        bs = BeautifulSoup(html, "html.parser")
        if x:
            trs = bs.select('tr.staticProp')[17].get_text()
        else:
            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")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

wb = Workbook()
ws = wb.active
ws['A1'] = "IP地址"
ws['B1'] = "总数"
n = 2
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',
       '192.168.70.24']

urls = ["http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
        "http://%s/web/guest/cn/websys/status/configuration.cgi"]
for i in ips:
    for url in urls:
        req = requests.get(url % i)
        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")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

TypeError: unsupported operand type(s) for %: 'list' and 'str'
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

req = requests.get(url % i)
我写的是url,你写的urls,仔细核对。
想知道小甲鱼最近在做啥?请访问 -> 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()
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

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

import requests
from bs4 import BeautifulSoup
from openpyxl import Workbook

wb = Workbook()
ws = wb.active
ws['A1'] = "IP地址"
ws['B1'] = "总数"
n = 2
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',
       '192.168.70.24']
urls = [f"http://%s/web/guest/cn/websys/status/getUnificationCounter.cgi",
        f"http://%s/web/guest/cn/websys/status/configuration.cgi"]
for i in ips:
    for x, url in enumerate(urls):
        req = requests.get(url % i)
        html = req.text
        bs = BeautifulSoup(html, "html.parser")
        if x:
            trs = bs.select('tr.staticProp')[17].get_text()
        else:
            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")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-13 15:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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