① 如何下载股票历史成交数据到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。
- 数据下载完成后,文件将保存在指定文件夹中,通过查看文件夹来获取爬取的数据。
与如何下载并分析股票数据库相关的资料
|