91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python3爬蟲學習之MySQL數據庫存儲爬取的信息詳解

發布時間:2020-09-30 12:43:54 來源:腳本之家 閱讀:216 作者:Veniendeavor 欄目:開發技術

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

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

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

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

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

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

Python3爬蟲學習之MySQL數據庫存儲爬取的信息詳解

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

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

Python3爬蟲學習之MySQL數據庫存儲爬取的信息詳解

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

# -*- 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'
}
# 獲得數據庫連接
connection = pymysql.connect(**db_config)
# 數據庫配置,獲得連接(參數方式)
# 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:
  # 獲得數據庫游標
  with connection.cursor() as cursor:
    sql = 'insert into titles(title, url) values(%s, %s)'
    for u in urls:
      # 執行sql語句
      cursor.execute(sql, (u.string, r'http://www.jianshu.com'+u.attrs['href']))
  # 事務提交
  connection.commit()
finally:
  # 關閉數據庫連接
  connection.close()

代碼執行結果:

Python3爬蟲學習之MySQL數據庫存儲爬取的信息詳解

更多關于Python相關內容可查看本站專題:《Python Socket編程技巧總結》、《Python正則表達式用法總結》、《Python數據結構與算法教程》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》

希望本文所述對大家Python程序設計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东乡县| 昌邑市| 沁水县| 霞浦县| 望奎县| 肃南| 无锡市| 平定县| 柯坪县| 南漳县| 富锦市| 恩平市| 嘉荫县| 日照市| 杭锦后旗| 山东| 佛冈县| 吉木萨尔县| 申扎县| 阿勒泰市| 如皋市| 婺源县| 安岳县| 榆中县| 滨州市| 靖宇县| 辉南县| 吴江市| 澳门| 盐池县| 客服| 嘉黎县| 景德镇市| 南京市| 白河县| 中山市| 闵行区| 定边县| 遂川县| 哈密市| 青田县|