激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

腳本之家,腳本語(yǔ)言編程技術(shù)及教程分享平臺(tái)!
分類(lèi)導(dǎo)航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務(wù)器之家 - 腳本之家 - Python - python使用xpath獲取頁(yè)面元素的使用

python使用xpath獲取頁(yè)面元素的使用

2022-01-04 00:32Sun@Python Python

本文主要介紹了python使用xpath獲取頁(yè)面元素的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

關(guān)于python 使用xpath獲取網(wǎng)頁(yè)信息的方法?

1、xpath的使用方法?

? XPath 使用路徑表達(dá)式來(lái)選取 XML 文檔中的節(jié)點(diǎn)或節(jié)點(diǎn)集。節(jié)點(diǎn)是通過(guò)沿著路徑 (path) 或者步 (steps) 來(lái)選取的。

常用路徑表達(dá)式含義

 

表達(dá)式 描述
/ 從根節(jié)點(diǎn)選取(取子節(jié)點(diǎn))
// 選擇的當(dāng)前節(jié)點(diǎn)選擇文檔中的節(jié)點(diǎn)
. 選取當(dāng)前節(jié)點(diǎn)。
選取當(dāng)前節(jié)點(diǎn)的父節(jié)點(diǎn)。
@ 選取屬性
* 表示任意內(nèi)容(通配符)
| 運(yùn)算符可以選取多個(gè)路徑

常用功能函數(shù)

 

函數(shù) 用法 解釋
startswith() xpath(‘//div[starts-with(@id,”ma”)]‘) #選取id值以ma開(kāi)頭的div節(jié)點(diǎn)
contains() xpath(‘//div[contains(@id,”ma”)]‘) #選取id值包含ma的div節(jié)點(diǎn)
and() xpath(‘//div[contains(@id,”ma”) and contains(@id,”in”)]‘) #選取id值包含ma的div節(jié)點(diǎn)
text() _.xpath('./div/div[4]/a/em/text()') #選取em標(biāo)簽下文本內(nèi)容

備注:

1、html中當(dāng)相同層次存在多個(gè)標(biāo)簽例如div,它們的順序是從1開(kāi)始,不是0
2、瀏覽器中使用開(kāi)發(fā)者工具可以快速獲取節(jié)點(diǎn)信息

python使用xpath獲取頁(yè)面元素的使用

2、實(shí)例:

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time    : 2021/9/7 9:35
# @Author  : Sun
# @Email   : [email protected]
# @File    : sun_test.py
# @Software: PyCharm


import requests
from lxml import etree


def get_web_content():
  try:
      url = "htpps://***keyword=%E6%97%A0%E9%92%A2%E5%9C%88&wq=%E6%97%A0%E"
"9%92%A2%E5%9C%88&ev=1_68131%5E&pvid=afbf41410b164c1b91d"
      "abdf18ae8ab5c&page=5&s=116&click=0 "
      header = {
          "user-agent": "Mozilla/5.0 (Windows NT 10.0; WOW64)"
          "AppleWebKit/537.36 (KHTML, like Gecko) "
                        "Chrome/75.0.3770.100 Safari/537.36 "}
      response = requests.request(method="Get", url=url, headers=header)
      result = response.text
      return result
  except TimeoutError as e:
      return None


def parsing():
  result = get_web_content()
  if result is not None:
      html = etree.HTML(result)
      # 先獲取一個(gè)大的節(jié)點(diǎn),包含了想要獲取的所有信息
      ii = html.xpath('//*[@id="J_goodsList"]/ul/li')
     
      for _ in ii:
      # 采用循環(huán),依次從大節(jié)點(diǎn)中獲取小的節(jié)點(diǎn)內(nèi)容
          # ''.join() 將列表中的內(nèi)容拼接成一個(gè)字符串
          infoResult = {
          	# @href 表示:獲取屬性為href的內(nèi)容
              'href': "https:" + _.xpath('./div/div[1]/a/@href')[0],
              'title': ''.join(
                      _.xpath('./div/div[2]/div/ul/li/a/@title')),
              # text()表示獲取節(jié)點(diǎn)i里面的文本信息
              'price': _.xpath('./div/div[3]/strong/i/text()')[0],
              'info': ''.join(
                      _.xpath('./div/div[4]/a/em/text()')).strip(),
              'province': _.xpath('./div/div[9]/@data-province')[0]}
          print(infoResult)
  else:
      raise Exception("Failed to get page information, please check!")
  
  return None


if __name__ == '__main__':
  parsing()

結(jié)果圖片:

python使用xpath獲取頁(yè)面元素的使用

到此這篇關(guān)于python使用xpath獲取頁(yè)面元素的使用的文章就介紹到這了,更多相關(guān)python xpath獲取頁(yè)面元素內(nèi)容請(qǐng)搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://blog.csdn.net/qq_40267002/article/details/120197707

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产第一页精品 | 最新在线黄色网址 | 高清做爰免费无遮网站挡 | 色综合久久久久久久久久久 | 久久精品一区二区三区国产主播 | 国产精品片一区二区三区 | 国产亚洲精品久久久久久久软件 | 正在播放91| 91久久免费 | 99seav| 国产99久久 | 极品xxxx欧美一区二区 | h色视频在线观看 | 毛片网站视频 | 欧美人人干 | 国产午夜精品久久久久久免费视 | 国产资源在线免费观看 | 热re91久久精品国产99热 | 亚洲四播房 | 国产美女爽到喷白浆的 | 91久久99热青草国产 | 成年人黄视频 | 福利在线免费视频 | 免看黄大片aa | 欧美性受xxxxxx黑人xyx性爽 | 成人在线免费小视频 | 国产91九色 | 久久精品久久久久 | 成人区一区二区 | 欧美精品一二三区 | 黄a大片| 成年人在线视频 | 欧美一级做一级爱a做片性 久久久资源网 | 亚洲第一成人在线视频 | 久久精品2019中文字幕 | 九九热精品免费 | 九九视频久久 | 欧美色大成网站www永久男同 | 国产一区不卡 | 狠狠操精品视频 | 中文字幕 亚洲一区 |