zoukankan      html  css  js  c++  java
  • 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文本的标签

      

  • 相关阅读:
    nginx 限流配置
    redis-sentinel 高可用方案实践
    redis之 主从复制和哨兵
    MySQL架构与业务总结图
    MGR实现分析
    通过 SCQA 的框架来讲故事
    MECE分析法
    如何提高问题的认知高度
    Mac 应用程序不能打开解决方法
    vscode打开文件在同一个tab的问题
  • 原文地址:https://www.cnblogs.com/youmingkuang/p/7843552.html
Copyright © 2011-2022 走看看