① 如何下載股票歷史成交數據到Excel或txt
以華中智能股票軟體為例:(以Think pad X13 銳龍版筆記本電腦,Windows 10 操作為例)首先切換到要下載數據的股票K線形態,按「F1」進入「日線某某股票歷史成交」,點擊滑鼠右鍵->數據導出->導出所有數據->在「請選擇導出的類型」中選擇excel或txt
補充資料:
如何獲取所有股票歷史數據:
如果要對股市進行分析,首先就要獲取所有股票的歷史數據,只有通過股票的歷史數據,我們才能分析出股市的規律。
(以Think pad X13 銳龍版筆記本電腦,Windows 10 操作為例)
一、工具/原料
1、EXCEL2007或者以上版本,不能使用WPS
2、電腦1g內存1核處理器及以上配置
3、擁有較強邏輯分析能力以及少量智慧及以上的大腦一顆
方法/步驟:
第一步,獲取股票代碼,復制其中一部分到第一個工作表A4到A127,然後通過程序把每一個代碼寫入到不同的工作表A2位置,並對該工作表以該股票代碼命名。程序如下:
Sub 工作表命名()
For i = 4 To 127
Sheets(i).Range("a2") = "'" & Sheets(1).Range("a" & i)
Next i
For i = 4 To Sheets.Count
Sheets(i).Name = Sheets(i).Range("a2").Value
Next
End Sub
第二步,獲取股票歷史數據。代碼如下:
Private Function GetSource(sURL As String) As String
Dim oXHTTP As Object
Set oXHTTP = CreateObject("MSXML2.XMLHTTP")
oXHTTP.Open "GET", sURL, False
oXHTTP.Send
GetSource = oXHTTP.responsetext
Set oXHTTP = Nothing
End Function
Sub 歷史數據()
Dim objXML As Object
Dim txtContent As String
Dim i As Integer
Dim strCode As String
Dim gp As String
Dim kaishihang
Dim arr, arr1, arr2, arr3, arr4, arr5, arr6, arr7, arr8, arr9, arr10, arr11
On Error Resume Next
EndRow = Range("a65536").End(xlUp).Row
startRow = 4
If startRow <= EndRow Then
Range(Cells(startRow, 1), Cells(EndRow, 11)).Value = ""
Else
Exit Sub
End If
Set objXML = CreateObject("Microsoft.XMLHTTP")
gp = [A2]
For h = 1 To 4
For m = 1 To 4
kaishihang = [A65535].End(xlUp).Row
nian = Replace(Str(Year(Now) + 1 - h), " ", "")
ji = Replace(Str(4 + 1 - m), " ", "")
With objXML
.Open "GET", "http://quotes.money.163.com/trade/lsjyj_" + gp + ".html?year=" + nian + "&season=" + ji + "", False
.Send
If objXML.Status = 200 Then
txtContent = .responsetext
arr = Split(txtContent, "'>
") For i = 1 To UBound(arr) arr1 = Split(arr(i), " | Cells(i + kaishihang, 1) = Right(Left(arr1(0), 10), 10) arr2 = Split(arr1(1), Chr(60)) Cells(i + kaishihang, 2) = Mid(arr2(0), InStr(arr2(0), ">") + 1) arr3 = Split(arr1(2), Chr(60)) Cells(i + kaishihang, 3) = Mid(arr3(0), InStr(arr3(0), ">") + 1) arr4 = Split(arr1(3), Chr(60)) Cells(i + kaishihang, 4) = Mid(arr4(0), InStr(arr4(0), ">") + 1) arr5 = Split(arr1(4), Chr(60)) Cells(i + kaishihang, 5) = Mid(arr5(0), InStr(arr5(0), ">") + 1) arr6 = Split(arr1(5), Chr(60)) Cells(i + kaishihang, 6) = Mid(arr6(0), InStr(arr6(0), ">") + 1) arr7 = Split(arr1(6), Chr(60)) Cells(i + kaishihang, 7) = Mid(arr7(0), InStr(arr7(0), ">") + 1) arr8 = Split(arr1(7), Chr(60)) Cells(i + kaishihang, 8) = Mid(arr8(0), InStr(arr8(0), ">") + 1) arr9 = Split(arr1(8), Chr(60)) Cells(i + kaishihang, 9) = Mid(arr9(0), InStr(arr9(0), ">") + 1) arr10 = Split(arr1(9), Chr(60)) Cells(i + kaishihang, 10) = Mid(arr10(0), InStr(arr10(0), ">") + 1) arr11 = Split(arr1(10), Chr(60)) Cells(i + kaishihang, 11) = Mid(arr11(0), InStr(arr11(0), ">") + 1) Next i End If End With Next m Next h Set objXML = Nothing End Sub 第三步,獲取上證歷史數據,並獲取所有股票的歷史數據。程序如下: Sub 所有股票歷史數據獲取() Application.ScreenUpdating = False Dim s As String, gp As String, nian As String, ji As String, s1 As String Dim arr, arr1, arr2, arr3, arr4, arr5, arr6, arr7, arr8, arr9 Dim i, h As Long Dim kaishihang Dim LastRow As Long, r As Long On Error Resume Next EndRow = Sheet2.Range("a65536").End(xlUp).Row startRow = 4 If startRow <= EndRow Then Sheet2.Range(Sheet2.Cells(startRow, 1), Sheet2.Cells(EndRow, 9)).Value = "" Else Exit Sub End If For h = 1 To 5 For m = 1 To 4 kaishihang = Sheet2.[A65535].End(xlUp).Row nian = Replace(Str(Year(Now) + 1 - h), " ", "") ji = Replace(Str(4 + 1 - m), " ", "") s1 = "http://quotes.money.163.com/trade/lsjysj_shu_000001.html?year=" + nian + "&season=" + ji + "" s = GetSource(s1) arr = Split(s, "'> | ") For i = 1 To UBound(arr) arr1 = Split(arr(i), " | Sheet2.Cells(i + kaishihang, 1) = Right(Left(arr1(0), 4), 4) & "-" & Right(Left(arr1(0), 6), 2) & "-" & Right(Left(arr1(0), 10), 2) arr2 = Split(arr1(1), Chr(60)) Sheet2.Cells(i + kaishihang, 2) = Mid(arr2(0), InStr(arr2(0), ">") + 1) arr3 = Split(arr1(2), Chr(60)) Sheet2.Cells(i + kaishihang, 3) = Mid(arr3(0), InStr(arr3(0), ">") + 1) arr4 = Split(arr1(3), Chr(60)) Sheet2.Cells(i + kaishihang, 4) = Mid(arr4(0), InStr(arr4(0), ">") + 1) arr5 = Split(arr1(4), Chr(60)) Sheet2.Cells(i + kaishihang, 5) = Mid(arr5(0), InStr(arr5(0), ">") + 1) arr6 = Split(arr1(5), Chr(60)) Sheet2.Cells(i + kaishihang, 6) = Mid(arr6(0), InStr(arr6(0), ">") + 1) arr7 = Split(arr1(6), Chr(60)) Sheet2.Cells(i + kaishihang, 7) = Mid(arr7(0), InStr(arr7(0), ">") + 1) arr8 = Split(arr1(7), Chr(60)) Sheet2.Cells(i + kaishihang, 8) = Mid(arr8(0), InStr(arr8(0), ">") + 1) arr9 = Split(arr1(8), Chr(60)) Sheet2.Cells(i + kaishihang, 9) = Mid(arr9(0), InStr(arr9(0), ">") + 1) Next i Next m Next h Application.ScreenUpdating = True n = Worksheets.Count For i = 4 To n Worksheets(i).Activate 歷史數據 Next End Sub 第四步,保存工作簿,並對該工作簿命名為1,然後復制該工作簿27份,把所有股票代碼寫入每一個工作簿第一個工作表的A3到A127列。然後根據第一步對工作簿內的工作表命名,並在每一個工作表A2單元格內寫入股票代碼。 第五步,把這些工作簿存放到炒股文件夾下的資料庫文件下。然後在炒股文件夾下新建一個工作簿,命名為「一鍵更新表格」,寫入如下代碼: Sub 所有股票歷史數據更新() Dim wb As Workbook For i = 1 To 27 Set wb = Workbooks.Open(ThisWorkbook.Path & "資料庫" & i & "".xlsb"") Application.Run ""'"" & wb.Path & """" & i & "".xlsb'!所有股票歷史數據獲取"" wb.Save wb.Close Next i End sub 當啟動這一段代碼以後,程序會自動一個一個的打開對應的工作簿然後獲取裡面所有股票的歷史數據,存放在對應的工作表當中。 第六步,對相應的程序添加按鈕,這樣,我們在啟動對應程序時,只需要點一下對應的按鈕就可以實現了。這樣,我們通過多個工作簿就實現了獲取所有股票歷史數據的方法。而後面,我們只需要通過獲取對應股票每一天的歷史數據,我們就能夠在任意一天很快速的能夠擁有所有股票的歷史數據了。 注意事項 1、在後續需要對這些數據進行分析,裡面會加入很多計算,所以啟動所有歷史數據更新時,我們應該要關閉自動更新。 2、因為歷史數據很大,所以這里只獲取四年的數據,想要獲取更多數據,可以更改程序裡面 「For h = 1 To 5」的那個5即可。 3、歷史數據的獲取需要較長的時間,要提前做好准備。 4、如果你想要弄清楚用EXCEL建立炒股系統的整套方法,請看後續內容。"
② 閫氳揪淇$殑杞浠舵庝箞涓嬭澆浠ュ墠鐨凨綰挎暟鎹鍟
閫氳揪淇¤蔣浠朵笅杞戒互鍓岾綰挎暟鎹鐨勬柟娉曞備笅錛
鍦ㄩ氳揪淇¤蔣浠朵腑錛屽彲浠ラ氳繃浠ヤ笅姝ラや笅杞戒互鍓嶇殑K綰挎暟鎹錛
棣栧厛錛屾墦寮閫氳揪淇¤蔣浠跺苟鐧誨綍璐﹀彿銆傚湪涓葷晫闈涓婏紝鎵懼埌騫剁偣鍑“緋葷粺”鑿滃崟錛岀劧鍚庨夋嫨“鐩樺悗鏁版嵁涓嬭澆”閫夐」銆傝繖涓閫夐」閫氬父浣嶄簬鑿滃崟鐨勫簳閮錛屽彲鑳介渶瑕佸悜涓嬫粴鍔ㄦ墠鑳界湅鍒般
鎺ヤ笅鏉ワ紝鍦ㄥ脊鍑虹殑“鐩樺悗鏁版嵁涓嬭澆”紿楀彛涓錛屽彲浠ョ湅鍒板氫釜閫夐」渚涢夋嫨銆備負浜嗕笅杞戒互鍓嶇殑K綰挎暟鎹錛岄渶瑕侀夋嫨“鏃ョ嚎”鎴“鍒嗛挓綰”絳夊瑰簲鐨凨綰跨被鍨嬨傛ゅ栵紝榪樺彲浠ラ夋嫨涓嬭澆鐨勬椂闂磋寖鍥村拰鍏蜂綋鐨勮偂紲ㄤ唬鐮併備緥濡傦紝濡傛灉鎯充笅杞芥煇鍙鑲$エ榪囧幓涓騫寸殑鏃ョ嚎鏁版嵁錛屽彲浠ラ夋嫨“鏃ョ嚎”綾誨瀷錛岃劇疆鏃墮棿鑼冨洿涓鴻繃鍘諱竴騫達紝騫惰緭鍏ョ浉搴旂殑鑲$エ浠g爜銆
瀹屾垚璁劇疆鍚庯紝鐐瑰嚮紿楀彛涓嬫柟鐨“寮濮嬩笅杞”鎸夐挳錛岄氳揪淇¤蔣浠跺氨浼氬紑濮嬩笅杞芥墍閫夎偂紲ㄥ湪鎸囧畾鏃墮棿鑼冨洿鍐呯殑K綰挎暟鎹銆備笅杞藉畬鎴愬悗錛岃繖浜涙暟鎹灝嗚嚜鍔ㄤ繚瀛樺湪杞浠剁殑鏁版嵁搴撲腑錛屽彲浠ュ湪杞浠朵腑榪涜屾煡鐪嬪拰鍒嗘瀽銆
鍊煎緱娉ㄦ剰鐨勬槸錛屼笅杞藉巻鍙睰綰挎暟鎹鍙鑳介渶瑕佷竴瀹氱殑鏃墮棿錛屽叿浣撳彇鍐充簬鏁版嵁閲忕殑澶у皬鍜岀綉緇滆繛鎺ョ殑閫熷害銆傛ゅ栵紝涓轟簡紜淇濇暟鎹鐨勫噯紜鎬э紝寤鴻鍦ㄤ笅杞藉墠媯鏌ョ綉緇滆繛鎺ユ槸鍚︾ǔ瀹氾紝騫剁『璁よ蔣浠剁増鏈鏄鍚︽渶鏂般
闄や簡閫氳繃杞浠跺唴緗鐨“鐩樺悗鏁版嵁涓嬭澆”鍔熻兘涓嬭澆鍘嗗彶K綰挎暟鎹澶栵紝榪樺彲浠ヨ冭檻浣跨敤鍏朵粬鏁版嵁婧愭垨絎涓夋柟宸ュ叿鏉ヨ幏鍙栬繖浜涙暟鎹銆備緥濡傦紝涓浜涢噾鋙嶆暟鎹鎻愪緵鍟嗗彲鑳芥彁渚涘巻鍙睰綰挎暟鎹鐨勪笅杞芥湇鍔★紝鎴栬呭彲浠ラ氳繃緙栧啓紼嬪簭鎴栦嬌鐢ㄧ埇鉶鎶鏈浠庣浉鍏崇綉絝欎笂鎶撳彇榪欎簺鏁版嵁銆傜劧鑰岋紝闇瑕佹敞鎰忕殑鏄錛屽湪浣跨敤絎涓夋柟宸ュ叿鎴栨湇鍔℃椂錛岄渶瑕佺『淇濇暟鎹鏉ユ簮鐨勫彲闈犳у拰鍚堟硶鎬э紝浠ラ伩鍏嶆綔鍦ㄧ殑娉曞緥椋庨櫓銆
鍙﹀栵紝瀵逛簬闇瑕侀戠箒涓嬭澆鍜屽垎鏋愬ぇ閲忓巻鍙睰綰挎暟鎹鐨勭敤鎴鳳紝寤鴻鑰冭檻浣跨敤涓撲笟鐨勯噾鋙嶆暟鎹緇堢鎴栬㈤槄鐩稿叧鐨勬暟鎹鏈嶅姟銆傝繖浜涚粓絝鎴栨湇鍔¢氬父鎻愪緵鏇村揩銆佹洿紼沖畾鐨勬暟鎹涓嬭澆鍜屾煡璇㈠姛鑳斤紝浠ュ強鏇翠赴瀵岀殑鏁版嵁鍒嗘瀽鍜屽彲瑙嗗寲宸ュ叿錛屽彲浠ュ府鍔╃敤鎴鋒洿鏈夋晥鍦拌繘琛屾姇璧勫喅絳栧拰鐮旂┒宸ヤ綔銆
鎬諱箣錛屽湪閫氳揪淇¤蔣浠朵腑涓嬭澆浠ュ墠鐨凨綰挎暟鎹鐩稿圭畝鍗曞拰鐩磋傘傞氳繃閫夋嫨閫傚綋鐨凨綰跨被鍨嬪拰鏃墮棿鑼冨洿錛屽苟杈撳叆鐩稿簲鐨勮偂紲ㄤ唬鐮侊紝鐢ㄦ埛鍙浠ヨ交鏉懼湴鑾峰彇鎵闇鐨勫巻鍙叉暟鎹銆傚悓鏃訛紝涔熷彲浠ヨ冭檻浣跨敤鍏朵粬鏁版嵁婧愭垨絎涓夋柟宸ュ叿鏉ヨ幏鍙栬繖浜涙暟鎹錛屼互婊¤凍涓嶅悓鐨勯渶奼傚拰鍦烘櫙銆
③ 利用Tushare獲取股票數據(全面詳細,照著敲就可以)
利用Tushare獲取股票數據的全面指南
Tushare是一個專為金融分析人員設計的免費Python財經數據介麵包,它簡化了從數據採集到存儲的過程,以pandas DataFrame格式提供高效的數據。通過Python的pandas、NumPy和Matplotlib,分析人員可以方便地進行數據處理和可視化,同時支持Excel和關系型資料庫的分析。Tushare覆蓋了股票、基金、期貨、數字貨幣等廣泛的數據內容,以及基本面數據,如公司財務和基金經理信息,且支持多語言的SDK和RESTful介面,適應不同用戶的需求。數據存儲選項包括Oracle、MySQL、MongoDB、HDF5和CSV,確保了數據獲取的性能和便利性。
安裝Tushare依賴環境只需執行pip install tushare,查看版本信息時,導入並列印tushare的__version__屬性即可。以下是使用Tushare獲取股票數據的步驟:
- 導入所需庫,如pandas、matplotlib和tushare。
- 設置數據格式和日期,使用qfq前復權方式獲取股票數據。例如,通過定義get_data函數獲取指定股票在特定日期范圍內的數據。
- 使用acquire_code函數下載股票數據,並保存為CSV文件。用戶需要輸入股票代碼、開始和結束日期。
- 運行acquire_code函數,輸入股票代碼,如600893.SH。
- 數據下載完成後,文件將保存在指定文件夾中,通過查看文件夾來獲取爬取的數據。
與如何下載並分析股票資料庫相關的資料
|