- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在努力学习python,我真的觉得“在硬道上学习python”、“python的一个字节”和“head-first python”都是很棒的书然而,现在我想开始一个“真正的”项目,lxml让我感觉像一个完整的git。
这就是我想做的(目标)
我正在分析一篇关于政治的报纸网站文章
网址http://politiken.dk/politik/
最终的项目应该
1)每天(可能每小时)访问
以上网址
2)对于每个相关的
文章,我想将url保存到
数据库。相关条款如下
在a<div class="w460 section_forside
中有些元素有图像,有些
sec-forside">
不。
我想保留以下内容:
A-标题(<h1 class="top-art-header fs-26">
)
B-副标题(<p class="subheader-art">
)
c-如果元素有相应的img,那么“alt”或“title”属性
3)访问每一个相关的URL,将文章正文刮去并保存到数据库中。
4)如果每个相关的URL已经在数据库中,那么我跳过该URL(上面定义的相关文章总是最新发布的10篇)
所需的结果应该是包含字段的数据库表:
第一条)身份证
第二条网址
第三条)标题
第二条)副标题
第三条
第三条)物品主体。
第三条)日期和时间(字符串位于<span class="date tr-upper m-top-2">
)
以上是我想帮助完成的。因为屏幕抓取并不总是好的,我想解释一下为什么我要这么做。
基本上我想挖掘
政党或政党的成员。我不会再版文章,出售数据或类似的东西(我没有检查我的方法的合法性,但希望和认为它应该是合法的)
我想我有一桌政客和一桌政党。
对于每一位政治家,我将拥有:
pol.i)身份证
pol.ii)名字
pol.iii)sur_名称
(ii)政党
对于每一个政党,我将拥有:
party.i)身份证
(二)正确名称
第三方名称
-党。ii)缩写
我想为几个丹麦报纸网站做这个,然后分析一家报纸
为一些政客/政党提供序言-仅基于提及次数。
我也需要帮助-但一步一个脚印:-)
稍后我将探讨NLTK和情感挖掘的可能性。
我想看看这是否能转化为政治学/新闻学的博士项目。
这基本上就是我所拥有的(即没有)
我真的很难理解lxml、元素的概念、不同的解析等等,当然我读过教程,但我仍然很难理解。
import lxml.html
url = "http://politiken.dk/politik/"
root = lxml.html.parse(url).getroot()
# this should retur return all the relevant elements
# does not work:
#relevant = root.cssselect("divi.w460 section_forside sec-forside") # the class has spaces in the name - but I can't seem to escape them?
# this will return all the linked artikles headlines
artikler = root.cssselect("h1.top-art-header")
# narrowing down, we use the same call to get just the URLs of the articles that we have already retrieved
# theese urls we will later mine, and subsequently skip
retrived_urls=[]
for a in root.cssselect("h1.top-art-header a"):
retrived_urls.append(a)
# this works.
最佳答案
这是很多要读的-也许你可以分成更小的具体问题。
关于lxml,here是一些例子official documentation也很好-花点时间来学习示例邮件列表非常活跃。
关于beautifulsoup,lxml是more efficient的,根据我的经验,它可以比beautifulsoup更好地处理断开的html。缺点是lxml依赖于C库,因此安装起来会更困难。
关于python - 帮助(或建议)我开始使用lxml,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5757201/
我有以下xml文件 10.10.0.135::3111 10.10.0.130::3111 10.10.0.129::3111 10.
我已经为 PyPy 创建了一个 virtualenv: virtualenv test -p `which pypy` source test/bin/activate 我安装了以下依赖项: sudo
我正在尝试使用 lxml 的 ElementTree etree 在我的 xml 文档中查找特定标签。标签如下所示: 12 我希望使用 etree.find('text:statedAge
在 python 3.5 项目中,我必须读取一些 xml 文件,因此我决定使用 lxml 库。由于我正在阅读文件,因此根据文档执行此操作的最有效方法是使用 lxml.etree.parse(...)
执行 pip install lxml 或 pip install pyquery 会出现此错误: gcc: error trying to exec 'cc1': execvp: No such f
我正在使用下面的代码获取一个部分的所有 html 内容以保存到数据库 el = doc.get_element_by_id('productDescription') lxml.html.tostri
我想以可区分的方式打印出 etree 的树结构(由 html 文档形成)(意味着两个 etree 应该以不同的方式打印出来)。 我所说的结构是指树的“形状”,基本上是指所有标签,但没有属性,也没有文本
谁能解释为什么第一次调用 root.cssselect() 有效,而第二次失败? from lxml.html import fromstring from lxml import etree htm
我收到此错误“ImportError: No module named lxml”,即使确实安装了 LXML。具体来说,它安装在项目的 python Virtualenv 中。最终我正在研究 Pyth
我在 Windows 32 位上使用 Anaconda v4.2 和 Python 3.5,并想使用 lxml etree。我的 Anaconda 发行版包括 lxml 3.6.4,但我的 IDE(P
我有一个脚本,可以从 URL 列表的 XML 文件中提取一些术语。所有 URL 都可以访问 XML 数据。 它在第一次正确打开、解析和提取时工作正常,但随后在过程中被某些 XML 文件中断并出现此错误
我正在使用 mechanize/cookiejar/lxml 来读取页面,它适用于某些页面但不适用于其他页面。我在其中遇到的错误是标题中的错误。我不能在这里发布页面,因为它们不是 SFW,但是有没有办
这是一个基本的问题,我实际上在文档中找不到它:-/ 如下: img = house_tree.xpath('//img[@id="mainphoto"]')[0] 如何获取 的 HTML标记? 我尝
我只想说,这个问题我已经在Pip is already installed: but I am getting no module named lxml看到了并且已经看到关于以非 root 用户身份安
我通过 pip 安装了 lxml 3.3.5。现在我在运行一些 Django 测试时遇到了问题: Traceback (most recent call last): File "manage.p
我有一个 Django 应用程序,其中包含 Tastypie 提供的 RESTFull 服务。我使用 easy_install 安装 lxml 和 defusedxml,这样我就可以使用 xml 而不
我正在使用 lxml etree 创建 xml 或 REST 调用。我有命名空间的问题,因为如果没有正确制定,我会从服务器收到语法错误。 正如您在以下 2 个示例中所看到的,我应该得到例如 ns1、n
我对导航具有 lxml.etree namespace 的 xml 文档感到有些困惑。 .我已经看到了一些关于这个主题的主题( 1 、 2 )以及 lxml docs但仍然没有想出答案。 xml =
由于各种原因,我试图从lxml.html.fromstring()切换到lxml.html.html5parser.document_fromstring()。两者之间的最大区别是,第一个返回lxml
我需要通过向现有元素添加子元素来修改现有的 xml 文件。我使用 lxml 库。 Eric Idle 999-999-999 555-555-555
我是一名优秀的程序员,十分优秀!