码迷,mamicode.com
首页 > 编程语言 > 详细

python 爬虫学习--Beautiful Soup插件

时间:2018-10-24 15:16:19      阅读:436      评论:0      收藏:0      [点我收藏+]

标签:col   地址   mes   请求   bsp   tab   中间   图片   增删改   

Beautiful Soup插件学习使用参考:https://www.crummy.com/software/BeautifulSoup/bs4/doc.zh/#recursive

 

使用Beautiful Soup前的准备,先确保安装了该插件(该版本为:beautifulsoup4):

C:\Program Files (x86)\Python36-32\Scripts>pip install beautifulsoup4
Requirement already satisfied: beautifulsoup4 in c:\program files (x86)\python36-32\lib\site-packages (4.6.3)

 

通过python自带的urllib.request模块解析目标网址:

#!/usr/bin/python
# -*- coding: UTF-8 -*-
from bs4 import BeautifulSoup
import urllib.request
import time
from python.common.ConnectDataBase import ConnectionMyslq


# 解析栏目数据
def getHtmlData(url):
    # 请求
    request = urllib.request.Request(url)

    # 结果
    response = urllib.request.urlopen(request)
    data = response.read()
    data = data.decode(gbk)
    return data

 

获取到需要解析的页面数据后,开始调用Beautiful Soup插件解析页面,提取需要的数据:

# 通过select样式选择器,选择需要的内容
def soupData2(data):
    soup = BeautifulSoup(data)
    # 获取今日推荐内容(使用样式选择器)
    infostag = soup.select(.today_news > ul > li > a)
    infos = list()
    for child in infostag:
        info = {}
        info[title] = child.get_text()
        info[href] = child.get(href)
        info[time] = time.strftime(%Y-%m-%d, time.localtime())
        # detailData = getHtmlData(child.get(‘href‘))
        # content = soupDetial(detailData)
        # info[‘content‘] = content
        #调用数据库方法,将数据入库
        insertInfo(info)
        # infos.append(info)
    # print(infos)

 

==============================================分割线===================================================================

接下来数据库的操作,前提条件安装了pymysql:

pymysql参考地址:https://github.com/PyMySQL/PyMySQL

C:\Program Files (x86)\Python36-32\Scripts>python -m pip install PyMySQL
Requirement already satisfied: PyMySQL in c:\program files (x86)\python36-32\lib\site-packages\pymysql-0.7.4-py3.6.egg (0.7.4)

 

导入数据库连接模块:

# 导入 pymysql
import pymysql

 

创建数据库连接类 和 对应的数据库操作方法:

‘‘‘
数据库连接
‘‘‘
class ConnectionMyslq(object):
    def __init__(self, ip, user_name, passwd, db, port, char=utf8):
        self.ip = ip
        self.port = port
        self.username = user_name
        self.passwd = passwd
        self.mysqldb = db
        self.char = char

        self.MySQL_db = pymysql.connect(
            host=self.ip,
            user=self.username,
            passwd=self.passwd,
            db=self.mysqldb,
            port=self.port,
            charset=self.char)

    # 查询数据
    def findList(self, sql):
        cursor = self.MySQL_db.cursor()
        MySQL_sql = sql
        try:
            # 执行SQL语句
            cursor.execute(MySQL_sql)
            # 获取所有记录列表
            results = cursor.fetchall()
        except Exception:
            print("Error: unable to fetch data")
            print(Exception)
            self.MySQL_db.close()
        self.MySQL_db.close()
        return results

    # 数据增删改查
    def exe_sql(self, sql):
        cursor = self.MySQL_db.cursor()
        MySQL_sql = sql
        try:
            # 执行SQL语句
            cursor.execute(MySQL_sql)
            self.MySQL_db.commit()
        except Exception:
            print("Error: unable to fetch data")
            print(Exception)
            self.MySQL_db.close()
        self.MySQL_db.close()

 

编写数据库操作的方法:

# 数据入库
def insertInfo(info):
    conn = ConnectionMyslq("localhost", "root",
                           "Gepoint", "pythondb", 3306)
    sql = insert into news_info(title, link, time) values("%s", "%s", "%s") % (
        info[title], info[href], info[time])
    conn.exe_sql(sql)
# 数据查询
def findAll():
    conn = ConnectionMyslq("localhost", "root",
                           "Gepoint", "pythondb", 3306)
    sql = select * from news_info
    result = conn.findList(sql)
    print(result)

 

 

 

最后执行方法:

if __name__ == "__main__":

    # 中间列数据接口 http://temp.163.com/special/00804KVA/cm_guonei_02.js?callback=data01_callback
    # 网易的今日推荐新闻
    data = getHtmlData(url=http://news.163.com/domestic/)
    soupData2(data)
  
findAll()
 

 

执行结果:

技术分享图片

 

python 爬虫学习--Beautiful Soup插件

标签:col   地址   mes   请求   bsp   tab   中间   图片   增删改   

原文地址:https://www.cnblogs.com/yin1361866686/p/9842777.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!