摘要:目標(biāo)從互聯(lián)網(wǎng)網(wǎng)易數(shù)據(jù)接口獲取股票歷史數(shù)據(jù),包括開(kāi)盤(pán)價(jià)最高價(jià)最低價(jià)收盤(pán)價(jià)等等環(huán)境記錄數(shù)條,以該表為基礎(chǔ),制作清單。
目標(biāo)
從互聯(lián)網(wǎng)(網(wǎng)易數(shù)據(jù)接口)獲取股票歷史數(shù)據(jù),包括開(kāi)盤(pán)價(jià)、最高價(jià)、最低價(jià)、收盤(pán)價(jià)等等
環(huán)境Python 3.6
MySQL 5.6.34
記錄數(shù):3592 條,以該表為基礎(chǔ),制作 mission 清單。
table: stock_list_20190209( mission list )從這個(gè)表里,每次讀取一定數(shù)量的記錄,依次從互聯(lián)網(wǎng)上獲取。
code: getStockData.py""" 《獲取股票歷史市值》 Created on 2018年2月12日 @author: Livon # 讀取 股票列表,含代碼及 上市日期、終止上市日期 (1)列表 每次執(zhí)行前,手工新建一個(gè)當(dāng)前日期的表,如果存在就刪除重建(可能是執(zhí)行一個(gè)存儲(chǔ)過(guò)程) 表名:stock_list_20180212 // 股票列表 表字段:id, 股票代碼, 是否順利完成,獲取記錄數(shù)量 每次取一條記錄,依次執(zhí)行,中斷了,下次可以從中斷處繼續(xù)。 (2) 每條記錄,按指定日期范圍進(jìn)行獲取 再建 # 從網(wǎng)易數(shù)據(jù)接口拉取市值數(shù)據(jù) # 存入表 stock_his_marketCap 中 """ import util import urllib import csv import time import datetimeUtil from urllib import request jobListTable = "stock_list_20180209" def p( msg ): print( "%s - %s" % ( datetimeUtil.getDatetime(), msg )) def startJob(): # 從數(shù)據(jù)池中讀取 n 記錄 missionList = util.getMissionList( jobListTable ) # 循環(huán)處理上述的 n 條記錄 for mission in missionList: # for value in row: # print( value ) # 根據(jù)記錄生成一條 url,一個(gè) url 可以獲取幾千條日記錄 url = util.genUrl( mission ) # url = "http://quotes.money.163.com/service/chddata.html?code=1000001&start=19910401&end=19910409" # url += "&fields=LCLOSE;TOPEN;HIGH;LOW;TCLOSE;CHG;PCHG;TURNOVER;VOTURNOVER;VATURNOVER;TCAP;MCAP" # print( dt(), " - ", url ) p( "url: %s" % url ) # 從互聯(lián)網(wǎng)上獲取股票數(shù)據(jù) dataList = util.getStockDataList( url ) if( dataList != None ): # 將數(shù)據(jù)保存在目標(biāo)表:股票歷史數(shù)據(jù)表中 insertedRows = util.insertTable( dataList ) # 更新 mission List 狀態(tài)標(biāo)志列 util.updateJobList( jobListTable, mission, insertedRows ) else : p( "csv 文件無(wú)數(shù)據(jù)。" ) p("standby a moment for next mission( you can terminal the program at this time).") time.sleep(3) # main for i in range( 0, 2 ): p( "startJob: %s" % str(i) ) startJob() # done print( "= = = = = = = = = = = = = = = = = = = = = = " ) p( "all done !") print( "= = = = = = = = = = = = = = = = = = = = = = " )code: util.py
""" Created on 2018年2月11日 @author: Livon """ import urllib.request import re import pymysql from urllib import request # from stock.獲取股票歷史市值 import datetimeUtil import datetimeUtil def p( msg ): print( "%s - %s" % ( datetimeUtil.getDatetime(), msg )) # 任務(wù)清單,每一次任務(wù)會(huì)領(lǐng)一份任務(wù)清單,清單中的第一項(xiàng),是一個(gè)股票 # 任務(wù):job - 大循環(huán) # 目標(biāo):mission - 小目標(biāo) # missionList - 目標(biāo)清單 # getMissionList # 參數(shù):tableName 表名 def getMissionList( tableName ): rowsCount = "5" ; conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="stock", charset="utf8") # 創(chuàng)建游標(biāo) # cursor = conn.cursor() cursor = conn.cursor() # sql="select * from "+ tableName +" where doneTime is NULL limit " + rowsCount sql = "select * from %s where doneTime is NULL limit %s" % ( tableName, rowsCount ) cout = cursor.execute(sql) # print("數(shù)量: "+str(cout)) rows = cursor.fetchall(); # rows = conn.cursor().execute( sql ).fetchall() # for row in rows: # print("stockCode: "+str(row[0])+" stockName: "+row[1]+" startDate: "+ str(row[2])) cursor.close() # # try: # #獲取一個(gè)游標(biāo) # with conn.cursor() as cursor: # sql="select * from "+ tableName +" where doneTime is NULL limit 1" # cout=cursor.execute(sql) # print("數(shù)量: "+str(cout)) # # for row in cursor.fetchall(): # #print("%s %s %s" %row) # #注意int類(lèi)型需要使用str函數(shù)轉(zhuǎn)義 # print("stockCode: "+str(row[0])+" stockName: "+row[1]+" startDate: "+ str(row[2])) # # conn.commit() # # finally: # print( "done" ) cursor.close() conn.close() # print( datetimeUtil.getDatetime(), " - 任務(wù)清單裝載完畢!任務(wù)數(shù)量:", str( len( rows )) ) # print( "%s - %s missons loaded." % ( datetimeUtil.getDatetime(), str( len( rows )) ) ) p( "%s missons loaded." % str( len( rows ) )) return rows # 生成網(wǎng)址 def genUrl( row ): stockCode = row[0] startDate = str( row[2] ).replace("-","") # endDate = ( row[3] == "None" )? "": row[3] # endDate = ( row[3] == None ) and "" or row[3] endDate = ( row[3] == None ) and row[3] or "" dataSource = row[4] # True and "Fire" or "Water" # print( row[3] is "None") # print( row[3] is None ) # print( row[3] is "" ) # print( type( row[3] ) ) # print( type( row[3] ) is None ) # print( type( row[3] ) is "NoneType" ) url = "http://quotes.money.163.com/service/chddata.html?code=%s%s&start=%s&end=%s" url = url % ( dataSource, stockCode, startDate, endDate ) url += "&fields=LCLOSE;TOPEN;LOW;HIGH;TCLOSE;CHG;PCHG;TURNOVER;VOTURNOVER;VATURNOVER;TCAP;MCAP" return url def getCsv( url ): # csv = csv.decode("gbk") # # csv_str = str(csv) # lines = csv_str.split(" ") # # print( len( lines)) return "" # 從互聯(lián)網(wǎng)上獲取數(shù)據(jù) def getStockDataList( url ): print( datetimeUtil.getDatetime(), " - ", "準(zhǔn)備從互聯(lián)網(wǎng)獲取數(shù)據(jù) ..." ) # http = urllib3.PoolManager() # r = http.request("GET", url ) # url="http://www.example.com/" # headers={"User-Agent":"Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1"} # try: # req = urllib3.request(url, headers ) # # req=urllib2.Request(url,headers=headers) # response = urllib3.request2.urlopen(req) # except urllib3.exceptions,e: # print e.reason dataList = None try: response = request.urlopen( url ) csv = response.read() csv = csv.decode("gbk") # csv = csv.decode("iso-8859-1") csv_str = str(csv) # print( type( csv )) if( len( csv_str ) < 1 ): print( "獲取失敗" ) # print( csv_str ) # lines = csv_str.split(" ") lines = csv_str.splitlines() # print( "行數(shù):" + str( len( lines ))) dataList = [] for line in lines: # print( line ) dataRow = line.split(",") # print( dataRow[0] ) dataObj = {} dataObj["日期"] = dataRow[0] dataObj["股票代碼"] = dataRow[1] dataObj["名稱(chēng)"] = dataRow[2] dataObj["前收盤(pán)"] = dataRow[3] dataObj["開(kāi)盤(pán)價(jià)"] = dataRow[4] dataObj["最高價(jià)"] = dataRow[5] dataObj["最低價(jià)"] = dataRow[6] dataObj["收盤(pán)價(jià)"] = dataRow[7] dataObj["漲跌額"] = dataRow[8] dataObj["漲跌幅"] = dataRow[9] dataObj["換手率"] = dataRow[10] dataObj["成交量"] = dataRow[11] dataObj["成交金額"] = dataRow[12] dataObj["總市值"] = dataRow[13] dataObj["流通市值"] = dataRow[14] dataList.append(dataObj) except Exception as e: print( e ) return dataList def netEaseUrl( stockCode, startDate, endDate ): url = "http://quotes.money.163.com/service/chddata.html?code=%s&start=%s&end=%s&fields=" url = url % ( stockCode, startDate, endDate ) print( url ) return url def receiveCsv( url ): # http://www.cnblogs.com/sysu-blackbear/p/3629420.html stockDataResponse = urllib.request.urlopen( url ) stockData = stockDataResponse.read() # stockData = stockDataResponse.decode("utf8") stockData = stockData.decode("gb2312") # stockData = stockData.decode("gb2312") # print( stockData ) return stockData """ """ def getStockList(): conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="stock", charset="utf8") # 創(chuàng)建游標(biāo) # cursor = conn.cursor() try: #獲取一個(gè)游標(biāo) with conn.cursor() as cursor: sql="select * from stock_list" cout=cursor.execute(sql) print("數(shù)量: "+str(cout)) for row in cursor.fetchall(): #print("%s %s %s" %row) #注意int類(lèi)型需要使用str函數(shù)轉(zhuǎn)義 print("stockCode: "+str(row[0])+" stockName: "+row[1]+" startDate: "+ str(row[2])) # conn.commit() finally: cursor.close() conn.close() def dbStore( str_stocks ): print( type( str_stocks )) stocks = re.findall("[(.*?)]",str_stocks ) stocks = re.findall("{(.*?)}",stocks[0]) # 創(chuàng)建連接 conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="stock", charset="utf8") # 創(chuàng)建游標(biāo) cursor = conn.cursor() for i in range( 0, len( stocks ) ): print( "No." + str(i)) properties = stocks[i].split(",") # print( properties ) # print( type( properties )) # effect_rows = insertDb( properties, cursor ) # time.sleep(1) # 提交,不然無(wú)法保存新建或者修改的數(shù)據(jù) conn.commit() # 關(guān)閉游標(biāo) cursor.close() # 關(guān)閉連接 conn.close() return "" def updateJobList( jobListTable, row, insertedRows ): # 創(chuàng)建連接 conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="stock", charset="utf8") # 創(chuàng)建游標(biāo) cursor = conn.cursor() # otherStyletime == "2013-10-10 23:40:00" # sql ="update " + jobListTable + " set doneTime = "" + otherStyleTime + "" where stockCode = "" + row[0] + """ sql = "update %s set doneTime = "%s" , receivedRows = %s where stockCode = "%s"" % ( jobListTable, datetimeUtil.getDatetime(), insertedRows, row[0] ) print( datetimeUtil.getDatetime(), " - 更新任務(wù)清單:", sql ) effect_row = cursor.execute( sql ) conn.commit() # 關(guān)閉游標(biāo) cursor.close() # 關(guān)閉連接 conn.close() def insertTable( dataList ): # 創(chuàng)建連接 conn = pymysql.connect(host="127.0.0.1", port=3306, user="root", passwd="root", db="stock", charset="utf8") # 創(chuàng)建游標(biāo) cursor = conn.cursor() insertedRows = 0 for i in range( 1, len( dataList )): for (k,v) in dataList[i].items(): # print( "dataList[i][%s]=" % k,v ) # print( v ) if( v == "None" ): # print("Change to NULL") dataList[i][k] = "NULL" # for data in dataList[i]: # print( data. ) # data = ( data == None ) and data or "NULL" sql = "INSERT INTO stock_his_data ( " sql += "日期," sql += "股票代碼," sql += "名稱(chēng)," sql += "前收盤(pán)," sql += "開(kāi)盤(pán)價(jià)," sql += "最低價(jià)," sql += "最高價(jià)," sql += "收盤(pán)價(jià)," sql += "漲跌額," sql += "漲跌幅," sql += "換手率," sql += "成交量," sql += "成交金額," sql += "總市值," sql += "流通市值" sql += " ) " sql += "VALUES" sql += " ( " sql += """ + dataList[i]["日期"] + ""," sql += """ + dataList[i]["股票代碼"]+ ""," sql += """ + dataList[i]["名稱(chēng)"] + ""," sql += dataList[i]["前收盤(pán)"] + " ," sql += dataList[i]["開(kāi)盤(pán)價(jià)"] + " ," sql += dataList[i]["最低價(jià)"] + " ," sql += dataList[i]["最高價(jià)"] + " ," sql += dataList[i]["收盤(pán)價(jià)"] + " ," sql += dataList[i]["漲跌額"] + " ," sql += dataList[i]["漲跌幅"] + " ," sql += dataList[i]["換手率"] + " ," sql += dataList[i]["成交量"] + " ," sql += dataList[i]["成交金額"]+ " ," sql += dataList[i]["總市值"] + " ," sql += dataList[i]["流通市值"] sql += " ) " # print( sql ) effect_row = cursor.execute( sql ) if( effect_row > 0 ): insertedRows += 1 print( datetimeUtil.getDatetime(), " - 數(shù)據(jù)數(shù)量:", insertedRows ) # # 提交,不然無(wú)法保存新建或者修改的數(shù)據(jù) conn.commit() # 關(guān)閉游標(biāo) cursor.close() # 關(guān)閉連接 conn.close() # arr_values = [] # arr_columns = [] # # for j in range( 0, len( properties) ): # # # print( "propertie["+ str(j)+"]: " + properties[j] ) # # key_value = properties[j].split(":") # # print( key_value[0] + " -> " + key_value[1] ) # key = properties[j][:properties[j].find(":")] # value = properties[j][properties[j].find(":")+1:] # value = value.replace(""", "") # # print( key + " -> " + value ) # # sql += """ + value + """ # arr_columns.append( "`" + key + "`" ) # # arr_columns.append( key ) # arr_values.append( """ + value + """ ) # # sql = "insert into stock_sina " # sql = sql + " ( " + ",".join( arr_columns ) + " ) VALUES ( " + ",".join( arr_values ) + " ) " # print( sql ) # effect_row = cursor.execute( sql ) return insertedRowscode: datetimeUtil.py
""" Created on 2018年2月14日 @author: Livon """ import time def getDatetime(): timeArray = time.localtime( time.time() ) otherStyleTime = time.strftime("%Y-%m-%d %H:%M:%S", timeArray) return otherStyleTime最終得到的數(shù)據(jù):table: stock_his_data
記錄總數(shù):9045612(九百萬(wàn))
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/41411.html
摘要:本例以數(shù)據(jù)庫(kù)為代表,展示將獲取到的股票數(shù)據(jù)存入數(shù)據(jù)庫(kù)的方法其他類(lèi)型數(shù)據(jù)庫(kù)請(qǐng)參考官網(wǎng)文檔的部分。存入數(shù)據(jù)庫(kù)追加數(shù)據(jù)到現(xiàn)有表財(cái)經(jīng)數(shù)據(jù)接口包的使用存入財(cái)經(jīng)數(shù)據(jù)接口包的使用 安裝TuShare 方式1:pip install tushare 方式2:訪問(wèn)https://pypi.python.org/pypi/tushare/下載安裝 方式3:將源代碼下載到本地python setup.py ...
摘要:目標(biāo)很簡(jiǎn)單,因?yàn)槲蚁胍酪幌伦C券化率,然后可視化輸出結(jié)果。證券化率的基礎(chǔ)就是上市公司的總市值,對(duì)于證券化率其實(shí)還蠻多說(shuō)法的,比如雪球的這篇文。我們可以利用這個(gè)回調(diào)函數(shù)來(lái)顯示當(dāng)前的下載進(jìn)度。 寫(xiě)在前面的叨叨 折騰了這么久,我終于在喝完一聽(tīng)快樂(lè)肥宅水后下定決心來(lái)學(xué)習(xí)寫(xiě)爬蟲(chóng)了。目標(biāo)很簡(jiǎn)單,因?yàn)槲蚁胍酪幌伦C券化率,然后可視化輸出結(jié)果。證券化率的基礎(chǔ)就是上市公司的總市值,對(duì)于證券化率其實(shí)還蠻多...
摘要:選取方法打開(kāi)網(wǎng)頁(yè),查看源代碼,搜索網(wǎng)頁(yè)的股票價(jià)格數(shù)據(jù)是否存在于源代碼中。將上述的代碼封裝成一個(gè)函數(shù),對(duì)東方財(cái)富網(wǎng)頁(yè)面解析的完整代碼如下所示接下來(lái)是獲得百度股票網(wǎng)鏈接描述單只股票的信息。 功能簡(jiǎn)介 目標(biāo): 獲取上交所和深交所所有股票的名稱(chēng)和交易信息。輸出: 保存到文件中。技術(shù)路線: requests---bs4--re語(yǔ)言:python3.5 說(shuō)明 網(wǎng)站選擇原則: 股票信息靜態(tài)存在于ht...
閱讀 1684·2023-04-26 00:30
閱讀 3157·2021-11-25 09:43
閱讀 2885·2021-11-22 14:56
閱讀 3195·2021-11-04 16:15
閱讀 1156·2021-09-07 09:58
閱讀 2029·2019-08-29 13:14
閱讀 3114·2019-08-29 12:55
閱讀 994·2019-08-29 10:57