python项目练习-1

获取无忧书城的小说内容!

python 复制代码
import requests  # 导入请求包
from lxml import etree  # 导入处理xml数据包

url = 'https://www.51shucheng.net/wangluo/douluodalu/21750.html'
book_num = 1  # 文章页数
download_urls = []  # 定义一个空列表,表示我们下载过小说的url!

while True:
    # UA头
    headers = {
        'User-Agent=': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/124.0.0.0 Safari/537.36'}

    resp = requests.get(url, headers=headers)  # 使用get方式请求数据!

    resp.encoding = 'utf-8'  # 将请求的数据编码为 utf-8的格式

    e = etree.HTML(resp.text)  # 使用etree模块处理数据,并赋值给e对象!
    data = ''.join(e.xpath('string(//div[@class="neirong"]/p)'))  # 使用xpath插件获取我需要的标签内容!
    title = e.xpath('//h1/text()')[0]  # 获取文章的标题

    if url in download_urls:
        print(f"跳过重复下载的章节: {title}")
    else:
        filename = f'output/斗罗大陆-第{book_num}章.txt'
        with open(filename, mode='w', encoding='utf-8') as file:
            file.write(title + "\n" + data)
        book_num += 1
        download_urls.append(url)  # 将已经下载章节的url添加到列表中!

    next_url = e.xpath('//div[@class="next"]/a/@href')[0]  # 使用xpath插件获取下一章节url在html标签内的位置!
    if not next_url:
        break
    url = next_url

不会用xpath的话,看下边!

比如我要获取每章节的标题在xml数据中的位置,请看如下图~

相关推荐
weixin_58061400几秒前
CSS如何处理CSS逻辑属性兼容性_通过PostCSS转译为物理属性
jvm·数据库·python
weixin_458580122 分钟前
CSS如何利用--first-letter设置首字下沉_通过文本伪元素打造报纸排版
jvm·数据库·python
亚林瓜子4 分钟前
AWS Catalog中数据搬到Catalog中
大数据·python·spark·云计算·aws·pyspark·glue
m0_493934536 分钟前
如何在 Go 中模拟 do-while 循环实现用户交互式重复执行
jvm·数据库·python
哈伦20197 分钟前
第六章 Matplotlib案例股票K线图绘制
python·matplotlib
阿_旭7 分钟前
基于YOLO26深度学习的【无人机视角DaMa检测】与语音提示系统【python源码+Pyqt5界面+数据集+训练代码】
python·深度学习·无人机
ccice017 分钟前
python爬虫——爬取全年天气数据并做可视化分析
开发语言·爬虫·python
m0_743623928 分钟前
如何用 removeChild 与 remove 方法从页面 DOM 中移除元素
jvm·数据库·python
userxxcc8 分钟前
Ginthon是用Python+Web写的“视图窗口+稳定服务”的桌面端(Win、Mac、Linux)多功能程序基座。开箱即用但有一定上手门槛。
python·pyinstaller·pywebview·桌面应用基座
InfinteJustice9 分钟前
JavaScript中null与undefined在双等号下的特殊性
jvm·数据库·python