• PyQuery


    强大又灵活的网页解析库。如果你觉得正则写起来太麻烦,如果你觉得Beauifulsoup语法太难记,如果你属性Jqueryd 语法,PyQuery是个不错的选择。

    pyquery 栗子

    初始化

    1、字符串初始化

    from pyquery import PyQuery as pq
    html ="""<ul id="navList">
    <title>标题</title>
    <header>大脑袋</header>
    <li name="drapname"><a id="blog_nav_sitehome" class="menu" href="http://www.cnblogs.com/">博客园</a></li>
    <li name="drm1"><a id="MyLinks1_SpaceLink" class="menu" href="http://ing.cnblogs.com/">闪存</a></li>
    <li><a id="blog_nav_myhome" class="menu" href="http://www.cnblogs.com/youmingkuang/">首页</a></li>
    <li><a id="blog_nav_newpost" class="menu" rel="nofollow" href="https://i.cnblogs.com/EditPosts.aspx?opt=1">新随笔</a></li>
    <li><a id="blog_nav_contact" accesskey="9" class="menu" rel="nofollow" href="https://msg.cnblogs.com/send/%E5%B9%BD%E5%86%A5%E7%8B%82_%E4%B8%83">联系</a></li>
    <li><a id="blog_nav_admin" class="menu" rel="nofollow" href="https://i.cnblogs.com/">管理</a></li>
    <li><a id="blog_nav_rss" class="aHeaderXML" href="http://www.cnblogs.com/youmingkuang/rss">订阅</a>
    <a id="blog_nav_rss_image" class="aHeaderXML" href="http://www.cnblogs.com/youmingkuang/rss"><img src="//www.cnblogs.com/images/xml.gif" alt="订阅" /></a></li>
    </ul>
    """
    doc = pq(html)
    print(doc('li')) //可以是样式.css或标签

    2、url初始化
    doc = pq(url='http://www.baidu.com')
    print(doc('head'))
    输出:
     

      3、文件初始化

    doc = pq(filename=r'D:QQ抓新建文本文档 (1).txt')
    print(doc.text()) //或者print(doc('标签、css样式'))

        4、基本CSS选择器

      doc = pq(html)

      print(doc('#cond .list li'))

    二、查找元素

      子元素

    doc = pq(html)
    items = doc('#navList')
    print(items)
    lis = items.find('li')
    print(lis)
    la = lis.find('a')
    print(la)

      父元素

    doc = pq(html)
    items = doc('a')
    pt = items.parent()
    print(pt)

    或者在精确一点查找
    pt = items.parent('.样式')
    print(pt)


      兄弟元素
      doc = pq(html)
      items = doc('a')
      pt = items.siblings()
      print(pt)

      遍历

        单个元素

    doc = pq(html)
    items = doc('a')
    print(items)

    多个元素
    doc = pq(html)
    items = doc('a').items()
    print(type(items))
    for l in items:
    print(l)

    获取信息
    获取属性
    doc = pq(html)
    items = doc('a')
    print(type(items))
    print(items.attr('href'))
    print(items.attr.href)


    获取文本
    doc = pq(html)
    items = doc('a')
    print(type(items))
    print(items.text())
    输出:
    博客园 闪存 首页 新随笔 联系 管理 订阅

    获取HTML
    doc = pq(html)
    items = doc('li')
    print(type(items))
    print(items.html())
    输出:

     DOM操作

    addClass、removeClass

    例子:
    doc=pq(html)
    li = doc('.item-0.active')
    print(li)
    li.removeClass('active')
    print(li)
    li.addClass('active')
    print(li)

     attr、css

     doc = pq(html)

     li =doc('.item-0.active')

        print(li)

        li.attr('name','link')

        print(li)

        li.css('font-size','14px')

        print(li)

        remove

        doc = pq(html)

        wrap = doc('.wrap')

      print(wrap.text())

        wrap.find('p').remove()

        print(wrap.text())

      伪类选择器

      

      from pyquery import PyQuery as pg

      doc = pq(html)

      li=doc('li:first-child')  //第一个标签

      li=doc('li:last-child')  //最一个标签

      li=doc('li:nth-child(2)')  //第二个标签

      li=doc('li:nth-child(2n)')  //获取偶数标签

      li = doc('li:contains(second)') //获取包含second文本的标签

      

  • 相关阅读:
    2.vue插件总结——总有你能用上的插件
    1.前端数据可视化插件:Highcharts、Echarts和D3(区别)
    git学习地址
    node vue 微信公众号(四)配置环境 本地测试
    解决element 分页组件,搜索过后current-page 绑定的数据变了,但是页面当前页码并没有变的问题
    导入excel并进行数据提取
    后端返回字符串中带换行符,前端需转换
    正则表达式tab表示
    FormData
    interval
  • 原文地址:https://www.cnblogs.com/youmingkuang/p/7843552.html
Copyright © 2020-2023  润新知