IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> python+selenium抓取网页新闻列表元素,保存到excel文档中 -> 正文阅读

[开发测试]python+selenium抓取网页新闻列表元素,保存到excel文档中

python+selenium:抓取网页新闻列表元素,并记录标题和链接地址,保存到excel文档中

#!/usr/local/bin/python3
# !python3.9
# -*- coding: UTF-8 -*-
'''
@File:xwzx1.py
@Time:2021-09-09 18:32
@Author:user
抓取网页新闻列表元素,并记录标题和链接地址,保存到excel文档中
'''
from selenium import webdriver
from os.path import join
import os
import sys
from time import strftime
from time import sleep
import xlrd
import xlwt

excel_dir=os.path.dirname(os.path.abspath(__file__))
now_time=strftime("%Y-%m-%d-%H-%M")


class text_xwzx():
    def __init__(self):

        self.url="http://www.sinopecgroup.com/group/xwzx/"
        self.filename=now_time+".xls"
        self.path=join(excel_dir,'data/')

    def getUTitle(self,driver,excel,row=0,col=0,rowlen=0):

        # 先找到ul->li,再找li->span.title->a,根据标签<a>属性,得到title和url
        ul = driver.find_element_by_css_selector("ul.w_newslistpage_list")
        atitles = ul.find_elements_by_css_selector("li>span.title>a")

        for title in atitles:
            atitle = title.text
            aurl = title.get_attribute("href")
            #当有分页时,先取得第一页的列表数量,作为第二页的开始,依次小于当前页列表的总数量
            #思路:1)当为首页时,row从0到列表总数;若为第二/三/四页时,把首页列表总数量,做为开始数,遍历当前页列表的总数;
            if(rowlen >= len(atitles)):
                row += 1
            else:
                row += 1

            excel.write(row, col, atitle)
            excel.write(row, col+1, aurl)
        return row

    def nextPage(self,driver):
        nextpage = driver.find_element_by_link_text("下一页")
        nextpage.click()
        sleep(10)

    def getData(self,modular):
        driver = webdriver.Chrome()
        driver.get(self.url+modular)
        sleep(10)

        #使用xlwt模块操作Excel的方法
        book = xlwt.Workbook(encoding = 'utf-8')
        # 先创建一个worksheet
        sh = book.add_sheet(modular)
        xwzx=text_xwzx()
        # 写入excel
        # 参数对应 row-行, col-列, 值
        rowlen=xwzx.getUTitle(driver,sh)

        print("rowlen=" , rowlen)
        xwzx.nextPage(driver)
        rowlen3=xwzx.getUTitle(driver,sh,rowlen,0,rowlen)
        print("rowlen3=" , rowlen3)
        xwzx.nextPage(driver)
        rowlen4=xwzx.getUTitle(driver, sh, rowlen3, 0, rowlen3)

        print("rowlen4=" , rowlen4)


        path_xls = self.path+self.filename
        print(path_xls)
        #保存文件,文件给文件一个名字
        book.save(path_xls)

if __name__ == '__main__':
    data=text_xwzx()
    data.getData('dqgz')

?

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-09-18 10:30:21  更:2021-09-18 10:30:29 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/18 0:43:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码