python3使用newspaper库提取新闻内容(readability,jparser)-泓源视野

python3使用newspaper库提取新闻内容(readability,jparser)

之前使用其他方法,诸如xpath,css,正则表达式,beautifulsoup来解析新闻页面的时候,总是会遇到这样那样各种奇奇怪怪的问题,让人很头疼。

最近学到一个新的包newspaper,用来抓取新闻正文,真的很好用呢。

这个包是需要自己重新安装的,我使用的是pycharm。

python3使用newspaper库提取新闻内容(readability,jparser)插图在settings配置环境,添加包newspaper的时候总是添加不进去。那就pip吧!

于是打开命令行窗口,输入pip3 install --ignore-installed --upgrade newspaper3k,等待一会就安装好了。

如果文章没有指明使用的什么语言的时候,Newspaper会尝试自动识别。

  1. from newspaper import Article
  2. url = '你想要爬取的网站url'
  3. news = Article(url, language='zh')
  4. news .download()
  5. news .parse()
  6. print(news.text)
  7. print(news.title)
  8. print(news.html)
  9. print(news.authors)
  10. print(news.top_image)
  11. print(news.movies)
  12. print(news.keywords)
  13. print(news.summary)

也可以直接导入包,如果语言是一致的,也可以直接声明

  1. import newspaper
  2. news = newspaper.build(url, language='zh')
  3. article = news.articles[0]
  4. article.download()
  5. article.parse()
  6. print(article.text)
  • GitHub:https://github.com/codelucas/newspaper
  • Newspaper文档说明:https://newspaper.readthedocs.io/en/latest/
  • Newspaper快速入门:https://newspaper.readthedocs.io/en/latest/user_guide/quickstart.html

Newspaper是一个python3库。

注:Newspaper框架并不适用于实际工程类新闻信息爬取工作,框架不稳定,爬取过程中会有各种bug,例如获取不到url、新闻信息等,但对于想获取一些新闻语料的朋友不妨一试,简单方便易上手,且不需要掌握太多关于爬虫方面的专业知识。

安装

pip3 install newspaper3k
or
pip3 install --ignore-installed --upgrade newspaper3k

如果文章没有指明使用的什么语言的时候,Newspaper会尝试自动识别。支持10多种语言并且所有的都是unicode编码。

import time
from newspaper import Article
url = 'https://www.chinaventure.com.cn/news/78-20190819-347269.html'
url='https://36kr.com/p/5237348'
# 创建文章对象
news = Article(url, language='zh')
# 下载网页
news.download()
## 网页解析
news.parse()
print("title=",news.title)# 获取文章标题
print("author=", news.authors) # 获取文章作者
print("publish_date=", news.publish_date) # 获取文章日期
# 自然语言处理
news.nlp()
print('keywords=',news.keywords)#从文本中提取关键字
print("summary=",news.summary)# 获取文章摘要
# time.sleep(30)
print("text=",news.text,"\n")# 获取文章正文
print("movies=",news.movies) # 获取文章视频链接
print("top_iamge=",news.top_image) # 获取文章顶部图片地址
print("images=",news.images)#从html中提取所有图像
print("imgs=",news.imgs)
print("html=",news.html)#获取html

也可以直接导入包,如果语言是一致的,也可以直接声明

import newspaper
url='http://www.coscocs.com/'
'''注:文章缓存:默认情况下,newspaper缓存所有以前提取的文章,并删除它已经提取的任何文章。
此功能用于防止重复的文章和提高提取速度。可以使用memoize_articles参数选择退出此功能。'''
news = newspaper.build(url, language='zh', memoize_articles=False)
article = news.articles[0]
article.download()
article.parse()
print('text=',article.text)
print('brand=',news.brand) #提取源品牌
print('description=',news.description) # 提取描述
print("一共获取%s篇文章" % news.size()) # 文章的数目
# 所有文章的url
for article in news.articles: print(article.url)
#提取源类别
for category in news.category_urls(): print(category)
#提取源提要
for feed_url in news.feed_urls(): print(feed_url)

注:文章缓存:默认情况下,newspaper缓存所有以前提取的文章,并删除它已经提取的任何文章。此功能用于防止重复的文章和提高提取速度。可以使用memoize_articles参数选择退出此功能。

Requests和Newspaper结合解析正文

import requests
from newspaper import fulltext
html = requests.get('https://www.washingtonpost.com/business/economy/2019/01/17/19662748-1a84-11e9-9ebf-c5fed1b7a081_story.html?utm_term=.26198c91916f').text
text = fulltext(html)
print(text)

Google Trends信息

import newspaper
print(newspaper.languages())#获取支持的语言
print(newspaper.hot())#hot()使用公共api返回谷歌上的热门词汇列表
print(newspaper.popular_urls())#popular_urls()返回一个流行新闻源url列表

多任务

import newspaper
from newspaper import news_pool
# 创建并行任务
slate_paper = newspaper.build('http://slate.com')
tc_paper = newspaper.build('http://techcrunch.com')
espn_paper = newspaper.build('http://espn.com')
papers = [slate_paper, tc_paper, espn_paper]
news_pool.set(papers, threads_per_source=2) # (3*2) = 6 共6个线程
news_pool.join()
print(slate_paper.articles[10].html)

python-readability

github地址是:https://github.com/buriy/python-readability

安装

pip install requests
pip install readability-lxml

使用方式:

import requests
from readability import Document
response = requests.get('https://news.163.com/18/1123/13/E1A4T8F40001899O.html')
doc = Document(response.text)
print doc.title()
print doc.content()

测试结果:正文提取范围太大,且乱码,不好用,拿到的正文部分,明显有问题。而且还有乱码问题。所以,不建议使用。

本文由 泓源视野 作者:admin 发表,其版权均为 泓源视野 所有,文章内容系作者个人观点,不代表 泓源视野 对观点赞同或支持。如需转载,请注明文章来源。
27
admin

发表评论

Protected with IP Blacklist CloudIP Blacklist Cloud
您是第8231291 位访客, 您的IP是:[3.238.227.73]