美文网首页
V1.2-爬取股票池每日数据-20180128

V1.2-爬取股票池每日数据-20180128

作者: 法正31 | 来源:发表于2018-01-27 17:12 被阅读0次

    得到了待爬取股票代码后,爬取该307支股票的过去3年历史数据,并分别存入excel。本文使用的是凤凰财经的api,没有使用headers与cookies,打算失败后再添加,不过顺利爬了下来。共耗时25分钟。后改用csv,耗时70秒,预计使用多线程(还不懂是什么意思,应该就是并发下载吧)
    本次学会的新技能:
    """
    新技能
    df = pd.read_excel(os.getcwd() + os.sep + 'stock.xlsx',converters = {u'证券代码':str})
    1、导入os包后,getcwd()可以获得当前代码文件所在的文件夹,os.sep为反斜杠""
    2、converters={u'证券代码':str},可以将代码中的002变为字符串格式。
    3、to_csv耗时70秒,to_excel耗时30分钟,所以除非使用的数据量小,或是导出的数据有直接使用格式的需求,否则尽量选择csv
    """

    import pandas as pd
    import numpy as np
    import requests
    import datetime
    
    starttime=datetime.datetime.now()
    def get_stock_pool_data():
        #读取已下载的股票池数据,获取代码与名称
        df=pd.read_excel("D:\\stock\\stock_pool20180127.xlsx",converters = {u"代码":str},sheetname="Sheet1")
        df=pd.DataFrame(df)
        df.rename(columns={"代码":"code","名称":"name"},inplace=True)
        print(df.head())
        df["city"]=np.where((df["code"].apply(lambda x:x[0:2])=="60"),"sh","sz")
        df["new_code"]=df["city"]+df["code"]
        return df
    
    def get_single_history(url):
        #获取单个股票历史数据
        page_source=requests.get(url).text
        dic=eval(page_source)#字符串转换为字典
        m=np.array(dic["record"])#访问字典,转化为矩阵
        columns=["date", "open", "high", "close", "low", "volume", 
                "chg", "%chg", "ma5", "ma10", "ma20", "vma5", "vma10", "vma20", "turnover"]
        df_history=pd.DataFrame(m,index=None,columns=columns)
        df_history=df_history.set_index("date")
        return df_history
    
    def get_every_history():
        #url="http://api.finance.ifeng.com/akdaily/?code=sh601012&type=last"
        url_fix1="http://api.finance.ifeng.com/akdaily/?code="
        url_fix2="&type=last"
        df_stock_pool_data=get_stock_pool_data()
        for i in df_stock_pool_data["new_code"]:
            stock_url=url_fix1+str(i)+url_fix2
            try:
                df_history=get_single_history(stock_url)
                df_history.to_csv("D:\\stock\\stock_csv\\"+str(i)[2:]+".csv")
            except Exception as e:
                print(e)
                continue
            #break #如果有了新的想法,测试是加上此句,只运行一句
    
    if __name__=="__main__":
        get_every_history()
        endtime=datetime.datetime.now()
        interval=(endtime-starttime).seconds
        print("共耗时%.2f秒"%interval)
    
    

    相关文章

      网友评论

          本文标题:V1.2-爬取股票池每日数据-20180128

          本文链接:https://www.haomeiwen.com/subject/yianaxtx.html