Python 3 爬蟲學習筆記 (四)

這是我自己在學習python 3爬蟲時的小筆記,做備忘用,難免會有一些錯誤和疏漏,望指正~~~
Python 3 爬蟲學習筆記 (一)
Python 3 爬蟲學習筆記 (二)
Python 3 爬蟲學習筆記 (三)
Python 3 爬蟲學習筆記 (五)
Python 3 爬蟲學習筆記 (六)


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

爬取到的數(shù)據(jù)為了更好地進行分析利用,而之前將爬取得數(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'
}

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

Paste_Image.png

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

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

Paste_Image.png

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

# -*- coding:utf-8 -*-

from urllib import request
from bs4 import BeautifulSoup
import 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.itdecent.cn/'
# 模擬瀏覽器頭
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ù)庫游標
    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.itdecent.cn'+u.attrs['href']))
    # 事務提交
    connection.commit()
finally:
    # 關閉數(shù)據(jù)庫連接
    connection.close()

代碼執(zhí)行結果:

Paste_Image.png
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 爬蟲文章 in 簡書程序員專題: like:128-Python 爬取落網(wǎng)音樂 like:127-【圖文詳解】py...
    喜歡吃栗子閱讀 22,677評論 4 411
  • # Python 資源大全中文版 我想很多程序員應該記得 GitHub 上有一個 Awesome - XXX 系列...
    aimaile閱讀 26,823評論 6 427
  • 1 前言 作為一名合格的數(shù)據(jù)分析師,其完整的技術知識體系必須貫穿數(shù)據(jù)獲取、數(shù)據(jù)存儲、數(shù)據(jù)提取、數(shù)據(jù)分析、數(shù)據(jù)挖掘、...
    whenif閱讀 18,290評論 45 523
  • 2017-09-13 今天是第一天來到光機所工程師培訓中心,很快的就和同學熟悉了,其實來之前內(nèi)心還是有些忐忑的,好...
    5期劉雪梅閱讀 210評論 1 0
  • 一鐘醉 欲箋心事終成昧,獨語斜闌風卻催。 木葉畫堂,雪落梅章。 此情能知未? 二鐘醉 錦字成書浮生累,青黛扣眉流年...
    君自白衣閱讀 555評論 12 17

友情鏈接更多精彩內(nèi)容