使用Selenium抓取QQ空間好友說說

代碼參考http://www.itdecent.cn/p/a6769dccd34d
剛接觸Selenium的戳這里Selenium與PhantomJS
PS:代碼的不足在于只能抓取第一頁的說說內(nèi)容,代碼的改進之處在于增加了與數(shù)據(jù)庫的交互,進行了存儲

1.安裝Selenium

pip install Selenium

2.在Python中使用Selenium獲取QQ空間好友說說

分析網(wǎng)頁結構

說說內(nèi)容
發(fā)表說說的時間

3.代碼實現(xiàn)(基于Python3)

# -*- coding:utf-8 -*-
from bs4 import BeautifulSoup
from selenium import webdriver
import time
import pymongo

# #使用Selenium的webdriver實例化一個瀏覽器對象,在這里使用Phantomjs
# driver = webdriver.PhantomJS(executable_path=r"D:\phantomjs-2.1.1-windows\bin\phantomjs.exe")
# #設置Phantomjs窗口最大化
# driver.maximize_window()


# 登錄QQ空間
def get_shuoshuo(qq):
    #建立與MongoClient的鏈接
    client = pymongo.MongoClient('localhost', 27017)
    #得到數(shù)據(jù)庫
    db = client['shuoshuo']
    #得到一個數(shù)據(jù)集合
    sheet_tab = db['sheet_tab']

    chromedriver = r"E:\mycode\chromedriver.exe"
    driver = webdriver.Chrome(chromedriver)
    #使用get()方法打開待抓取的URL
    driver.get('http://user.qzone.qq.com/{}/311'.format(qq))
    time.sleep(5)
    #等待5秒后,判斷頁面是否需要登錄,通過查找頁面是否有相應的DIV的id來判斷
    try:
        driver.find_element_by_id('login_div')
        a = True
    except:
        a = False
    if a == True:
        #如果頁面存在登錄的DIV,則模擬登錄
        driver.switch_to.frame('login_frame')
        driver.find_element_by_id('switcher_plogin').click()
        driver.find_element_by_id('u').clear()  # 選擇用戶名框
        driver.find_element_by_id('u').send_keys('QQ號')
        driver.find_element_by_id('p').clear()
        driver.find_element_by_id('p').send_keys('QQ密碼')
        driver.find_element_by_id('login_button').click()
        time.sleep(3)
    driver.implicitly_wait(3)

    #判斷好友空間是否設置了權限,通過判斷是否存在元素ID:QM_OwnerInfo_Icon
    try:
        driver.find_element_by_id('QM_OwnerInfo_Icon')
        b = True
    except:
        b = False
    #如果有權限能夠訪問到說說頁面,那么定位元素和數(shù)據(jù),并解析
    if b == True:
        driver.switch_to.frame('app_canvas_frame')
        content = driver.find_elements_by_css_selector('.content')
        stime = driver.find_elements_by_css_selector('.c_tx.c_tx3.goDetail')
        for con, sti in zip(content, stime):
            data = {
                'time': sti.text,
                'shuos': con.text
            }
            print(data)
            sheet_tab.insert_one(data)
        pages = driver.page_source
        soup = BeautifulSoup(pages, 'lxml')

    #嘗試一下獲取Cookie,使用get_cookies()
    cookie = driver.get_cookies()
    cookie_dict = []
    for c in cookie:
        ck = "{0}={1};".format(c['name'], c['value'])
        cookie_dict.append(ck)
    i = ''
    for c in cookie_dict:
        i += c
    print('Cookies:', i)


    driver.close()
    driver.quit()


if __name__ == '__main__':
    get_shuoshuo('好友的QQ號')

注意:使用前記得安裝chromedriver這個插件,使用的過程中會呼起一個谷歌瀏覽器。如果寫了絕對路徑還報錯的話,就加入環(huán)境變量。

通過Robo 3T(數(shù)據(jù)庫MongoDB的一款功能強大的數(shù)據(jù)庫管理工具)可以看到我們已經(jīng)將拿到的數(shù)據(jù)庫存儲于數(shù)據(jù)庫中

接下來我們應該通過拿到的數(shù)據(jù)做一些數(shù)據(jù)分析...可是我不會!??!

正在努力學習數(shù)據(jù)分析中.....

如果你覺得我的文章還可以,可以關注我的微信公眾號:Python攻城獅

可掃描二維碼,添加關注

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

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

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,810評論 25 709
  • 轉(zhuǎn)自Selenium WebDriver注意:本章內(nèi)容官方團隊正在完善中。 介紹 WebDriver### Sel...
    抓兔子的貓閱讀 7,886評論 2 22
  • 看到這個第一眼是時間飛逝,2017居然過去了一半,我在干些什么?我都干了些什么? 很遺憾,上半年,拖延,沒有理財觀...
    王小蝦喲閱讀 774評論 3 0
  • 原本今天晚上是準備去寫畢業(yè)論文的,卻被圖書館多功能廳前面的一張福山雅治叔的海報牽住腳步,看標題是推理小說書友會,...
    DUDU六花閱讀 489評論 0 0
  • 從前,有一位叫比莉的女孩,她喜歡去沙漠探險。 一天,比莉穿上衣服,背上包,去沙漠探險了。 她走呀走呀,突然看到一盞...
    實彌義勇我老婆閱讀 492評論 0 2

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