【python实用小脚本-182】Python一键爬取今日新闻:5分钟生成Word+CSV——再也不用复制粘贴

Python一键爬取今日新闻:5分钟生成Word+CSV------再也不用复制粘贴

新闻爬虫, 自动导出, Word+CSV, 零配置, 瑞士军刀

故事开场:一把瑞士军刀救了早八的你

周一早八,老师布置任务:"整理今天国内外 50 条新闻要点做汇报。"

你打开浏览器,复制标题→作者→正文→粘贴到 Word,手指抽筋到第 5 条就崩溃。

这时,你从桌面掏出"小白瑞士军刀"------news_scraper.py

双击运行,30 秒后:

  • news.txt:纯文本要点
  • news.docx:带格式的 Word
  • news.csv:Excel 直接透视

汇报材料一次性到位,老师点赞:"效率真高!"

痛点解决:再也不用一条条手动复制,5 分钟搞定今日新闻全格式。


完整代码(≤1000字符,直接展示)

python 复制代码
import requests, datetime as dt
from bs4 import BeautifulSoup
from docx import Document
import pandas as pd

today = dt.date.today()
page = requests.get("https://inshorts.com/en/read/")
soup = BeautifulSoup(page.content, 'html.parser')

headlines = [s.get_text() for s in soup.find_all('span', itemprop="headline")]
authors   = [s.get_text() for s in soup.find_all('span', class_="author")[::2]]
dates     = [s.get_text() for s in soup.find_all('span', class_="date")]
times     = [s.get_text() for s in soup.find_all('span', class_="time")]
bodies    = [s.get_text() for s in soup.find_all('div', itemprop="articleBody")]

final = [
    {'Title': h, 'Author': a, 'Date': d, 'Time': t, 'Details': b}
    for h, a, d, t, b in zip(headlines, authors, dates, times, bodies)
]

# 1) 纯文本
with open("news.txt", "w", encoding="utf-8") as f:
    f.write(f"NEWS {today}\n")
    for item in final:
        for k, v in item.items():
            f.write(f"{k}: {v}\n")
        f.write("\n")

# 2) Word
doc = Document()
doc.add_heading(f"NEWS {today}", 0)
for item in final:
    p = doc.add_paragraph("")
    for k, v in item.items():
        p.add_run(f"{k}: {v}\n")
doc.save("news.docx")

# 3) CSV
pd.DataFrame(final).to_csv("news.csv", index=False)

代码解析

功能块 1:一页爬全站

requests + BeautifulSoup 一句拿到 HTML,再用 find_all 批量抓标题/作者/正文。

python 复制代码
soup.find_all('span', itemprop="headline")

功能块 2:数据一键打包

把五条信息放进字典列表,zip 配对,避免索引错位。

python 复制代码
final = [{'Title': h, 'Author': a, ...} for h, a, d, t, b in zip(...)]

功能块 3:三格式同步输出

  • 纯文本:最轻量,手机也能看
  • Word:带标题、段落,汇报直接交
  • CSV:Excel 透视,图表随便做
python 复制代码
pd.DataFrame(final).to_csv("news.csv", index=False)

如果还想更厉害

扩展点子 1:自定义关键词过滤

--keyword 人工智能,只保留含关键词的新闻。

python 复制代码
import argparse
parser = argparse.ArgumentParser()
parser.add_argument("--keyword", default="")
args = parser.parse_args()
final = [f for f in final if args.keyword.lower() in f['Details'].lower()]

扩展点子 2:GUI 拖拽

tkinter 做个窗口,拖 CSV 或点按钮即可重新导出。

python 复制代码
import tkinter as tk, tkinter.filedialog as fd
root = tk.Tk()
csv_path = fd.askopenfilename(filetypes=[("CSV", "*.csv")])
df = pd.read_csv(csv_path)

总结

news_scraper.py 这把 30 行瑞士军刀,把"开网页→复制→粘贴→排版"四步压缩成"双击→收工"。

你无需安装任何大型软件,就能把实时新闻变成 TXT、Word、CSV 三件套。

再加两行参数或 GUI,它就从脚本升级成新闻工厂。

下次再被老师/老板要"今日要点",直接甩文件!

源码获取

完整代码已开源,包含详细的注释文档:

🔗 [GitCode仓库] https://gitcode.com/laonong-1024/python-automation-scripts

📥 [备用下载] https://pan.quark.cn/s/654cf649e5a6 提取码:f5VG

相关推荐
badhope1 小时前
Mobile-Skills:移动端技能可视化的创新实践
开发语言·人工智能·git·智能手机·github
码云数智-园园2 小时前
微服务架构下的分布式事务:在一致性与可用性之间寻找平衡
开发语言
吴佳浩3 小时前
GPU 编号进阶:CUDA\_VISIBLE\_DEVICES、多进程与容器化陷阱
人工智能·pytorch·python
C++ 老炮儿的技术栈3 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl3 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
Liu628883 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
IT猿手3 小时前
基于控制障碍函数的多无人机编队动态避障控制方法研究,MATLAB代码
开发语言·matlab·无人机·openclaw·多无人机动态避障路径规划·无人机编队
全栈凯哥3 小时前
18.Python中的导入类完全指南
python
AI科技星3 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘
sunwenjian8863 小时前
Java进阶——IO 流
java·开发语言·python