教你如何从网易金融下载股票CSV数据,用于量化投资分析使用!

**首先呢,我不是做IT人士,我也不是学CS专业的。写的不好,可以优化的地方,请多多指教。**有兴趣学习Python的童鞋可以来看我的知乎帖子。

首先呢,站得知道网址的存在形式与格式:
“http://quotes.money.163.com/service/chddata.html?code=0688366&start=20190107&end=20200404”
code = 0######代表着60的股票,举例0600110就是“诺德股份”的;
_______1######代表的是30和00开头的股票,举例1002230就是“科大讯飞”的,1300375就是“宁德时代”的;
start = 你要从那一天开始下载代码,举例20190101就是2019年1月1日;
end = 你要下载截止到那一天,举例20200501就是2020年5月1日;

好的,然后咱们上代码:

import time
import requests
import os


def worker(begin_date, today_date):  # 首先我们创建一个函数,这里的举例是下载300001 ~ 300449的股票代码
    for stock_codes in range(1, 450):  # 我个人选择了range来进行loop
        try:  # 这个try是用于判定我们之前下载股票信息的修改日期(以后会用到)
            modifiedTime = time.localtime(os.stat('__stock__\\SZ\\3{:0>5}.csv'.format(stock_codes)).st_mtime)  # 判定建档日期
            mTime = time.strftime('%Y%m%d', modifiedTime)  # 将日期格式化为YYYYMMDD的格式
            if today_date != mTime:  # 如果我硬盘上的文件修改日期跟今天不一致
                try:  # 这个try是用于判定下载的有效性
                    f = requests.get('http://quotes.money.163.com/service/chddata.html?code=130'
                                     + str(stock_codes).zfill(4)
                                     + '&start=' + begin_date
                                     + '&end=' + today_date)  # 这里就是下载链接的格式化,因为我们要加变量进去
                    with open('__stock__\\SZ\\3{:0>5}.csv'.format(stock_codes), 'wb+') as code:
                        code.write(f.content)  # 存储文件
                    if stock_codes == 449:  # 如果下载完300449的代码,告诉我以下信息
                        print('\r' + "股票历史信息储存为: 3{:0>5}.csv  第陆进程结束!".format(stock_codes))
                    # else:
                    # print('\r' + "股票历史信息储存为: 3{:0>5}.csv  --@#6".format(stock_codes))
                except requests.exceptions.ProxyError:  # 如果出现下载问题就提示我
                    print("进程6异常结束")
            else:  # 如果我硬盘上的文件修改日期跟今天一致,那就告诉我以下信息
                print('\r' + "股票3{:0>5}.csv今天已经更新过了!".format(stock_codes))
                continue
        except FileNotFoundError:  # 如果硬盘里面没有找到下载过的代码,那就下载它吧。
            try:
                f = requests.get('http://quotes.money.163.com/service/chddata.html?code=130'
                                 + str(stock_codes).zfill(4)
                                 + '&start=' + begin_date
                                 + '&end=' + today_date)
                with open('__stock__\\SZ\\3{:0>5}.csv'.format(stock_codes), 'wb+') as code:
                    code.write(f.content)
                if stock_codes == 449:
                    print('\r' + "股票历史信息储存为: 3{:0>5}.csv  第陆进程结束!".format(stock_codes))
                else:
                    print('\r' + "股票历史信息储存为: 3{:0>5}.csv  --@#6".format(stock_codes))
            except requests.exceptions.ProxyError:
                print("进程6异常结束")


if __name__ == "__main__":
	root_path = '__stock__'  # 这个看个人哈,看你想把数据放在哪里
	starting = str(20150101)
	as_of_today = str(dt.now().strftime('%Y%m%d'))  # 当天日期的代码

	worker()

整体的套路就是这样啦,希望对有兴趣的朋友有帮助。

当然了,也可以用tushare或者baostock的来获取信息,看看您的用途是啥吧。

PS: 代码里面有两个非常好用的希望大家能够在以后的Python运用中使用到,

  1. 3{:0>5}的意思就是3后面加5五位带零的,如果代码是300123的话,避免出现3123这种错误。
  2. .zfill的用途和上面相似,像300001的话,我们用的是for loop,那么1就需要0001来显示,所以.zfill(4)。

你可能感兴趣的:(量化投资,python,大数据)