股票數(shù)據(jù)的網(wǎng)站抓取(4.1)代碼優(yōu)化

代碼優(yōu)化

  1. 沒增加任何新功能,僅僅是想讓代碼至少自己看起來舒服些
  2. 對(duì)firefox配置adblock,通過firefox配置文件模式減少廣告的載入
  3. 盡量減少相似的代碼
  4. 盡量使用子程序增加可維護(hù)性
  5. 將啟動(dòng)兩個(gè)firefox優(yōu)化為啟動(dòng)一個(gè)
  6. 為下一步多線程模式打下個(gè)基礎(chǔ)
#coding=utf-8
from selenium import webdriver
import time
import os
import re
import sys  
from selenium.common.exceptions import NoSuchElementException
reload(sys)  
sys.setdefaultencoding('utf8')   
#######################
def getinfo(mydriver,g_myfile,gourl):
    linetext=""
    mydriver.get(gourl)
    try:
        gupiaoming=mydriver.find_element_by_xpath(title).text
        gupiaocode=mydriver.find_element_by_xpath(code).text
        hexinshuju=mydriver.find_element_by_class_name('pad5')
        shujuhang=hexinshuju.find_elements_by_tag_name('tr')
        for i in range(len(shujuhang)-2):
            shujulie=shujuhang[i].find_elements_by_tag_name('td')
            tmpshuju=myre.split(shujulie[0].text)
            linetext=linetext+"~"+tmpshuju[1]
        shuju=myre.split(shujuhang[8].text)
        linetext=linetext+"~"+shuju[1]
        tmpshuju=myre.split(shujuhang[9].text)
        linetext=linetext+"~"+tmpshuju[1]
        linetext="%s~%s%s"%(gupiaoming,gupiaocode,linetext)
        print "數(shù)據(jù)寫入",linetext
        g_myfile.write("%s\n"%(linetext))
    except  NoSuchElementException,e:
        print "不是股票"

def saveinfob(s_filename,s_list):
    s_myfile=open(s_filename,'w')
    for s_myurl in s_list:
        print s_myurl
        if s_myurl!=None:
            getinfo(br,s_myfile,s_myurl)
    s_myfile.close()

#通過link對(duì)象獲得鏈接地址的text文本
def getlinkurl(linklist):
    my=[]
    for x in linklist:
        my.append(x.get_attribute('href'))
    return my

def geturls(mydriver):
    sz=[]
    sh=[]
    br.get("http://quote.eastmoney.com/stocklist.html")
    shxpath="/html/body/div[9]/div[2]/div/ul[1]"
    szxpath="/html/body/div[9]/div[2]/div/ul[2]"
    shgupiao=br.find_element_by_xpath(shxpath)
    szgupiao=br.find_element_by_xpath(szxpath)
    shgupiaolist=shgupiao.find_elements_by_tag_name('a')
    szgupiaolist=szgupiao.find_elements_by_tag_name('a')
    
    sh=getlinkurl(shgupiaolist)
    sz=getlinkurl(szgupiaolist)
    return sh,sz

######################
#firefox配置文件目錄
profileDir = "/Users/pro/Desktop/mystudy/python"
profile = webdriver.FirefoxProfile(profileDir)
#加載帶有配置文件的firefox
br=webdriver.Firefox(profile)
#獲得所有鏈接地址
(sh,sz)=geturls(br)

title='//*[@id="name"]'
code='//*[@id="code"]'
hexinshujuxpath="/html/body/div[14]/div[1]/div[4]/div[1]"
restr=":".decode('utf8')
myre=re.compile(restr,re.I|re.M|re.S)

#獲得數(shù)據(jù)并保存
saveinfob('tmpshgupiaodata.txt',sh)
saveinfob('tmpszgupiaodata.txt',sz)
br.quit()
print "數(shù)據(jù)下載完成"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,355評(píng)論 25 708
  • Ubuntu的發(fā)音 Ubuntu,源于非洲祖魯人和科薩人的語言,發(fā)作 oo-boon-too 的音。了解發(fā)音是有意...
    螢火蟲de夢(mèng)閱讀 100,838評(píng)論 9 468
  • 人生中,很多東西在得到的時(shí)候,其實(shí)也是失去,小時(shí)候渴望長大,但長大了缺發(fā)現(xiàn)遺失了童年的快樂,長大后渴望甜蜜,但走進(jìn)...
    沉默雨佳閱讀 192評(píng)論 0 0
  • 一部一部找好電視劇,在虛構(gòu)的故事里品帓人生冷暖,愛恨情·仇
    風(fēng)無用閱讀 318評(píng)論 0 0
  • 算法 先用2去篩,即把2留下,把2的倍數(shù)剔除掉;再用下一個(gè)素?cái)?shù),也就是3篩,把3留下,把3的倍數(shù)剔除掉;接下去用下...
    byene閱讀 665評(píng)論 0 0

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