国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python3爬蟲學(xué)習(xí)之MySQL數(shù)據(jù)庫存儲爬取的信息詳解

2020-02-16 00:04:51
字體:
供稿:網(wǎng)友

本文實例講述了Python3爬蟲學(xué)習(xí)之MySQL數(shù)據(jù)庫存儲爬取的信息。分享給大家供大家參考,具體如下:

數(shù)據(jù)庫存儲爬取的信息(MySQL)

爬取到的數(shù)據(jù)為了更好地進(jìn)行分析利用,而之前將爬取得數(shù)據(jù)存放在txt文件中后期處理起來會比較麻煩,很不方便,如果數(shù)據(jù)量比較大的情況下,查找更加麻煩,所以我們通常會把爬取的數(shù)據(jù)存儲到數(shù)據(jù)庫中便于后期分析利用。

這里,數(shù)據(jù)庫選擇MySQL,采用pymysql 這個第三方庫來處理python和mysql數(shù)據(jù)庫的存取,python連接mysql數(shù)據(jù)庫的配置信息

db_config ={  'host': '127.0.0.1',  'port': 3306,  'user': 'root',  'password': '',  'db': 'pytest',  'charset': 'utf8'}

以爬取簡書首頁文章標(biāo)題以及url為例,先分析抓取目標(biāo)信息,

如上圖,文章題目在a標(biāo)簽中,且url(href)只含有后半部分,所以在存儲的時候,最好把它補(bǔ)全。

mysql:新建一個數(shù)據(jù)庫pytest,建立一張名為titles的表,表中字段分別為id(int自增),title(varchar),url(varchar),如下:

進(jìn)行數(shù)據(jù)庫操作的思路為:獲得數(shù)據(jù)庫連接(connection)->獲得游標(biāo)(cursor)->執(zhí)行sql語句(execute)->事物提交(commit)->關(guān)閉數(shù)據(jù)據(jù)庫連接(close),具體代碼實現(xiàn)如下:

# -*- coding:utf-8 -*-from urllib import requestfrom bs4 import BeautifulSoupimport pymysql# mysql連接信息(字典形式)db_config ={  'host': '127.0.0.1',  'port': 3306,  'user': 'root',  'password': '',  'db': 'pytest',  'charset': 'utf8'}# 獲得數(shù)據(jù)庫連接connection = pymysql.connect(**db_config)# 數(shù)據(jù)庫配置,獲得連接(參數(shù)方式)# connection = pymysql.connect(host='127.0.0.1',#            port=3306,#            user='root',#            password='',#            db='pytest',#            charset='utf8')url = r'http://www.jianshu.com/'# 模擬瀏覽器頭headers = {  'User-Agent':'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/55.0.2883.87 Safari/537.36'}page = request.Request(url, headers=headers)page_info = request.urlopen(page).read().decode('utf-8')soup = BeautifulSoup(page_info, 'html.parser')urls = soup.find_all('a', 'title')try:  # 獲得數(shù)據(jù)庫游標(biāo)  with connection.cursor() as cursor:    sql = 'insert into titles(title, url) values(%s, %s)'    for u in urls:      # 執(zhí)行sql語句      cursor.execute(sql, (u.string, r'http://www.jianshu.com'+u.attrs['href']))  # 事務(wù)提交  connection.commit()finally:  # 關(guān)閉數(shù)據(jù)庫連接  connection.close()

代碼執(zhí)行結(jié)果:

更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python Socket編程技巧總結(jié)》、《Python正則表達(dá)式用法總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 梁平县| 治多县| 凌海市| 湟中县| 阜城县| 始兴县| 化隆| 通道| 和龙市| 靖江市| 淳安县| 崇礼县| 屏南县| 昭通市| 安溪县| 金湖县| 大理市| 永城市| 福建省| 嵩明县| 虹口区| 澄城县| 五莲县| 正宁县| 安吉县| 徐闻县| 道孚县| 丹凤县| 宕昌县| 钦州市| 谢通门县| 墨脱县| 九龙坡区| 台江县| 衡阳县| 泗阳县| 景德镇市| 两当县| 大厂| 阿尔山市| 合川市|