weixin_46617641 2022-05-18 16:29 采纳率: 92.3%
浏览 179
已结题

tushare爬虫提示'NoneType' object has no attribute 'head'

问题相关代码,请勿粘贴截图
ts.get_tick_data('000300',date='2021-10-20',src='tt').head()#历史分笔数据
# vpin计算,其中start,end为时间,code为股票代码,注意tushare的高频数据最早到20186月
def vpin(start, end, code):
    tradeday = get_trade_days(start_date=start, end_date=end)
    firstday = ts.get_tick_data(code, date=str(tradeday[0]), src='tt')
    firstdayvol = firstday['volume'].sum()
    bulkvol = firstdayvol / 50
    result = pd.DataFrame(columns=('date', 'vpin', 'high', 'low', 'open', 'close'))
    datelist = []
    allchange = []
    for i in tradeday:

        day = ts.get_tick_data(code, date=str(i), src='tt')
        if day is not None:
            day['volcum'] = day['volume'].cumsum()
            day['number'] = day['volcum'] // bulkvol
            n = int(max(day['number']))

            for j in range(0, n):
                bulk = day[day['number'] == j]
                if len(bulk) > 0:
                    change = (bulk.iloc[-1]['price'] / bulk.iloc[0]['price']) - 1
                    allchange.append(change)

    std = np.std(np.array(allchange))

    for i in tradeday:
        day = ts.get_tick_data(code, date=str(i), src='tt')
        if day is not None:
            chglist = []
            vpinlist = []
            day['volcum'] = day['volume'].cumsum()
            day['number'] = day['volcum'] // bulkvol
            n = int(max(day['number']))
            high = max(day['price'])
            low = min(day['price'])
            Open = day['price'].iloc[0]
            Close = day['price'].iloc[-1]

            for j in range(0, n):
                bulk = day[day['number'] == j]
                if len(bulk) > 0:
                    change = (bulk.iloc[-1]['price'] / bulk.iloc[0]['price']) - 1
                    chglist.append(change)
            for change in chglist:
                z = (change) / std
                p = (1.0 + erf(z / sqrt(2.0))) / 2.0
                vpinlist.append(abs(((1 - p) - p)))
        vpin = np.mean(np.array(vpinlist))
        result = result.append(
            pd.DataFrame({'date': [i], 'vpin': [vpin], 'high': [high], 'open': [Open], 'low': [low], 'close': [Close]}),
            ignore_index=True)
    return result
运行结果及报错内容

img

  • 写回答

1条回答 默认 最新

  • 二九筒 2022-05-18 16:42
    关注

    你 print一下这个ts.get_tick_data('000300',date='2021-10-20',src='tt') 看是不是None

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月11日
  • 已采纳回答 8月3日
  • 创建了问题 5月18日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分