怎么在Python中使用beautifulSoup4爬取數(shù)據(jù)?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括蚌埠網(wǎng)站建設(shè)、蚌埠網(wǎng)站制作、蚌埠網(wǎng)頁制作以及蚌埠網(wǎng)絡(luò)營銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,蚌埠網(wǎng)站推廣取得了明顯的社會效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到蚌埠省份的部分城市,未來相信會繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!具體如下:
#! /usr/bin/python3 # -*- coding:utf-8 -*- from urllib.request import urlopen as open from bs4 import BeautifulSoup import re import pymysql def find_top_ten(url): response = open(url) bs = BeautifulSoup(response,'html.parser') tags = bs.select('span.tag-item a') top_ten_href = [tag.get('href') for tag in tags] top_ten_tag = [tag.text for tag in tags] # print(top_ten_href) # print(top_ten_tag) return top_ten_href def insert_into_mysql(records): con = pymysql.connect(host='localhost',user='root',password='root',database='quotes',charset='utf8',port=3306) cursor = con.cursor() sql = "insert into quotes(content,author,tags) values(%s,%s,%s)" for record in records: cursor.execute(sql, record) con.commit() cursor.close() con.close() # http://quotes.toscrape.com/tag/love/ #要獲取對應(yīng)標(biāo)簽中所有的名言 所以這里要考慮分頁的情況 #經(jīng)過在網(wǎng)頁上查看知道分頁查詢的url #http://quotes.toscrape.com/tag/love/page/1/ #判斷到那一頁沒有數(shù)據(jù) div.container div.row [1] def find_link_content(link): page = 1 while True: new_link = "http://quotes.toscrape.com" + link + "page/" # print(new_link) new_link = new_link + str(page) print(new_link) sub_bs = open(new_link) sub_bs = BeautifulSoup(sub_bs,'html.parser') quotes = sub_bs.select('div.row div.col-md-8 span.text') # 如果沒有數(shù)據(jù)就退出 if len(quotes) == 0: break #名言 quotes = [quote.text.strip('“”') for quote in quotes] #作者 authors = sub_bs.select('small.author') authors = [author.text for author in authors] # 標(biāo)簽 tags_list = sub_bs.select('meta.keywords') tags_list = [tags.get('content') for tags in tags_list] # print(authors) # print(quotes) #print(tags_list) record_list = [] for i in range(len(quotes)): tags = tags_list[i] tags = tags.replace(',',',') print(tags) record = [quotes[i],authors[i],tags] record_list.append(record) insert_into_mysql(record_list) page += 1 # def main(): url = "http://quotes.toscrape.com/" parent_link = find_top_ten(url) for link in parent_link: print(link) find_link_content(link) if __name__ == '__main__': main()
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司的支持。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計(jì)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。