PyQuery笔记

PyQuery笔记1、初始化1.1、字符串初始化frompyqueryimportPyQueryaspyhtml=”’<div>  <ul>    <liclass="item-0">firstitem</li>    <liclass="item-1"><ahref="htt

大家好,又见面了,我是你们的朋友全栈君。

1、初始化

1.1、字符串初始化

from pyquery import PyQuery as py

html = '''
<div>
   <ul>
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''

doc = py(html)
print(doc('li'))

1.2、URL初始化

from pyquery import PyQuery as py

# 通过URL来获取
doc = py(url='http://www.baidu.com')
# <class 'pyquery.pyquery.PyQuery'>
print(type(doc('title')))
# 输出选中的head标签
print(doc('head'))

1.3、文件的初始化

from pyquery import PyQuery as py

# 通过文件来获取
doc = py(filename='demo1.html')
# <class 'pyquery.pyquery.PyQuery'>
print(type(doc('li')))
# 输出所有的li标签
print(doc('li'))

2、基本的CSS选择器

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''

doc = py(html)
# 选中idcontainer中的classlist中的li标签
print(doc('#container .list li'))

3、查找元素

3.1、子元素

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
# 获取classlist的元素
items = doc('.list')
# <class 'pyquery.pyquery.PyQuery'>
print(type(items))
print(items)
# 在先前找到的元素中获取li标签
lis = items.find('li')
# <class 'pyquery.pyquery.PyQuery'>
print(type(lis))
print(lis)
# 获取先前找到的元素中的所有子元素
lis2 = items.children()
print(type(lis2))
print(lis2)
# 获取先前找到的元素中的class为active的元素
li3 = items.children('.active')
print(li3)

3.2、父元素

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
# 获取classlist的元素
items = doc('.list')
# 获取所选元素的父元素
container = items.parent()
print(type(container))
print(container)
print("==========================")
# 获取所选元素的所有父元素
parents = items.parents()
print(type(parents))
print(parents)
print("==========================")
# 获取所选元素的所有父元素中classcontainer的元素
parent = items.parents('.container')
print(parent)

3.3、兄弟元素

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
# 获取classlist的元素
items = doc('.list')
li = doc('.list .item-0.active')
# 查找选中元素的所有兄弟元素(不包含自己)
print(li.siblings())
# 查找选中元素的所有兄弟元素中classactive的元素(不包含自己)
print(li.siblings('.active'))



4、遍历

4.1、单个元素

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)

# 选中单个单个元素
li = doc('.item-0.active')
print(li)

4.2、多个元素

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)

# 查找所有li标签
lis = doc('li').items()
# <class 'generator'>
print(type(lis))
forli inlis:
   print(li)



5、获取信息

5.1、获取属性

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
a = doc('.item-0.active a')
# <a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a>
print(a)
# link3.html    获取选中标签的href属性
print(a.attr('href'))
# link3.html
print(a.attr.href)

5.2、获取文本

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
a = doc('.item-0.active a')
# <a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a>
print(a)
# 获取a标签的内容
print(a.text())

5.3、获取HTML

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
li = doc('.item-1.active')
# <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
print(li)
# 获取li标签的HTML
print(li.html())



6、DOM操作

6.1、addClass、removeClass

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
li = doc('.item-0.active')
print(li)
# 移除class
li.removeClass('active')
print(li)
# 添加class
li.addClass('active')
print(li)

6.2、attr、css

from pyquery import PyQuery as py

html = '''
<div id="container">
   <ul class="list">
        <li class="item-0">first item</li>
        <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
        <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
        <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
        <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
    </ul>
</div>
'''
doc = py(html)
li = doc('.item-0.active')
print(li)
# 添加name属性
li.attr('name', 'link')
print(li)
# 添加css样式
li.css('font-size', '14px')
print(li)

6.3、remove

from pyquery import PyQuery as py

html = '''
<div class="wrap">
   Hello, World
   <p>This is a paragraph.</p>
</div>
'''
doc = py(html)
wrap = doc('.wrap')
print(wrap.text())
# 在选择的元素中找到p标签并移除
wrap.find('p').remove()
print(wrap.text())

6.4、其他DOM方法

http://pyquery.readthedocs.io/en/latest/api.html



7、伪类选择器

from pyquery import PyQuery as py

html = '''
<div class="wrap">
   <div id="container">
       <ul class="list">
            <li class="item-0">first item</li>
            <li class="item-1"><a href="https://ask.hellobi.com/link2.html">second item</a></li>
            <li class="item-0 active"><a href="https://ask.hellobi.com/link3.html"><span class="bold">third item</span></a></li>
            <li class="item-1 active"><a href="https://ask.hellobi.com/link4.html">fourth item</a></li>
            <li class="item-0"><a href="https://ask.hellobi.com/link5.html">fifth item</a></li>
        </ul>
    </div>
</div>
'''

doc = py(html)
# 找到第一个li
li = doc('li:first-child')
print(li)
# 找到最后一个li
li = doc('li:last-child')
print(li)
# 找到第二个li
li = doc('li:nth-child(2)')
print(li)
# 找到第三个到最后的li
li = doc('li:gt(2)')
print(li)
# 找到第偶数个li
li = doc('li:nth-child(2n)')
print(li)
# 找到内容包含secondli
li = doc('li:contains(second)')
print(li)

更多的选择器 

http://www.w3school.com.cn/css/index.asp



8、官方文档

http://pyquery.readthedocs.io/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131346.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 求中位数Python_统计学中位数众数例题

    求中位数Python_统计学中位数众数例题首先需要数据源,这里随便写了一个:nums=[1,2,3,4]求均值和中位数均可以使用numpy库的方法:#均值np.mean(nums)#中位数np.median(nums)求众数方法一:在numpy中没有直接的方法,但是也可以这样实现:importnumpyasnpcounts=np.bincount(nums)#返回众数np.argmax(counts)  …

    2025年12月15日
    2
  • Linux(Centos7)机器间做互信

    Linux(Centos7)机器间做互信

    2021年5月15日
    119
  • ubuntu卸载安装的方式

    ubuntu卸载安装的方式1、查找已经安装的插件查看全部:dpkg-l查看相关:dpkg-l|grep<筛选目标>例如:dpkg-l|grepgcc2、卸载apt-getremove<dpkg-l的结果>例如:apt-getremovelibgcc-4.8-dev注意:卸载过程中会有依赖关系而产生报错,需要自己确认相互依赖的关系,遵循…

    2022年5月29日
    35
  • ma3d舞台建模教程_3d渲染需要什么配置

    ma3d舞台建模教程_3d渲染需要什么配置2019.8.9更新:Smart3D现在对所有的.s3c文件都进行了加密,已经不能直接设置txt文件,但是依旧可以使用CC_S3CComposer.exe进行编辑创建。但是官网下载的.s3c文件还进一步有设置,不能进行编辑更改,因此请下载我提供的.s3c文件进行操作。以下步骤根据最新.s3c格式进行编写。一、须知:S3C是Smart3D内部格式,实质上是一个分块模型的索引,可以…

    2022年10月7日
    4
  • 【转AekdyCoin】求小于等于N的与N互质的数的和「建议收藏」

    【转AekdyCoin】求小于等于N的与N互质的数的和「建议收藏」话说我以前求这样的问题都是先求与N不互质的数,把N分解质因数,然后用容斥原理,今天看了大牛的博客,顿时觉得弱爆了。。。以下内容转大牛文章:ifgcd(n,i)=1thengcd(n,n-i)=1(1反证法:如果存在K!=1使gcd(n,n-i)=k,那么(n-i)%k==0而n%k=0那么必须保证i%k=0k是n的因子,如果i%k=0那么gcd(n,i)=k

    2022年7月23日
    15
  • Java Scanner类的常用方法及用法(很详细)

    Java Scanner类的常用方法及用法(很详细)JavaScanner类的方法及用法(很详细)Scanner类简介Java5添加了java.util.Scanner类,这是一个用于扫描输入文本的新的实用程序。它是以前的StringTokenizer和Matcher类之间的某种结合。由于任何数据都必须通过同一模式的捕获组检索或通过使用一个索引来检索文本的各个部分。于是可以结合使用正则表达式和从输入流中检索特定类型数据项的方法。这样,除…

    2022年7月7日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号