首頁 >後端開發 >Python教學 >讓Python更方便-簡介Python常用的標準函式庫與介紹

讓Python更方便-簡介Python常用的標準函式庫與介紹

Tomorin
Tomorin原創
2018-08-15 17:31:471764瀏覽

Python中到底有哪些Python常用函式庫會讓程式設計師愛不釋手?以至於一次上癮,今天我們就來整理一番這樣的Python常用庫,歡迎各位在評論區或者私信我添加或者修改相關庫內容。

首先介紹beautifulsoup這個庫,因為最開始接觸爬蟲的時候,就看到大家強力推薦這個庫。後來用了下,覺著確實不錯。但是程式設計師嘛,哪能在一個庫裡悶死,哈哈。

幾個函式庫的安裝過程就不再累述,參考anaconda。 -_-.

後面幾個實例,兩者都用這個來測試。

html = """
<html><head><title>The Dormouse&#39;s story</title></head>
<body>
<p class="myclass" name="dromouse"><b>The Dormouse&#39;s story</b></p>
<p class="story">Once upon a time there were three little sisters; and their names were
<a href="http://example.com/elsie" class="myclass" id="box"><!-- Elsie --></a>,
<a href="http://example.com/lacie" class="myclass" id="box1">Lacie</a> and
<a href="http://example.com/tillie" class="myclass" id="box2">Tillie</a>;
and they lived at the bottom of a well.</p>
<p class="story">...</p>
"""

BeautifulSoup

#Beautiful Soup支援Python標準函式庫中的HTML解析器,也支援一些第三方的解析器。例如lxml HTML,lxml XML,html5lib。不過要安裝這些函式庫,否則它會使用python的內部標準函式庫。

  beautifulsoup的物件創建有兩種方式。

1.  soup=BeautifulSoup(html) #用變數內容來建立

2.  soup=BeautifulSoup('mysite.html') #使用本機檔案建立

# BeautifulSoup是將HTML轉化為一個複雜的樹狀結構,每個節點都是python對象,有前端基礎的同學會知道,類似DOM對象。 BeautifulSoup中的物件大致有四種,Tag、NavigableString、BeautifulSoup、Comment。由於我們平時操作大多數是針對一個個標籤提取訊息,所以我簡略的敘述下常用到的Tag物件。

Tag

tag就是HTML的一個標籤。

例如HTML中的 head,title,a,p等等。

在實際操作中,我們會將所需的標籤透過選擇器找出來,然後透過操作Tag物件來取得所需資訊。在BeautifulSoup中,常用的findAll()和find()來搜尋文件樹來取得自己所需的標籤。同時,BeautifulSoup也支援CSS語法來搜尋,select()方法,傳回的類型是list。  

ps:

1.findAll()等同於find_all()2.對前端比較了解的,用select()方法比較順手。

find()

find()相當於findAll()中limit=1的時候,不過find()回傳的是結果,findAll()回傳的是一個列表。

CSS選擇器#########  beautifulsoup支援CSS語法的選擇器來尋找所需的標籤。 ###
select(CSS选择器)
例:
soup.select(&#39;.myclass #box&#39;)
#后代选择器
soup.select(&#39;head>title&#39;)
#子选择器
soup.select(&#39;div+p&#39;)
#相邻兄弟选择器
soup.select(&#39;div~p’)
#后续兄弟选择器
###同時也可以加入屬性查找。 ###
soup.select(&#39;.myclass a[id="box"]&#39;)
###select()方法傳回的是列表形式。 ######以上差不多就是BeautifulSoup常用的功能###

以上是讓Python更方便-簡介Python常用的標準函式庫與介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn