求教,Python小问题,加粗部分为什么会报错???

def calculation_wr(trading_dates,sectors,pf_data):
    # Part 1: 初始化一些存储用的中间变量
    pf_weights = pd.DataFrame(0, columns=sectors, index=td_dates).astype('float') # 存储持仓权重
    pf_values = pd.DataFrame(0, columns=sectors, index=td_dates).astype('float') # 存储所持头寸在各行业在各交易日末的市值
    pf_cin = pd.DataFrame(0, columns=sectors, index=td_dates).astype('float') # 存储所持头寸在个交易日各行业的现金流入情况(卖股)
    pf_cout = pd.DataFrame(0, columns=sectors, index=td_dates).astype('float') # 存储所持头寸在个交易日各行业的现金流出情况(买股)
    pf_r = pd.DataFrame(0, columns=sectors, index=td_dates).astype('float') # 存储持仓收益率
    # Part 2: 计算过程
    for d in td_dates:
        data_sub2=pf_data[pf_data['持仓日期']==d]
        for s in sectors:
            data_sub1=pf_data[(pf_data['行业']==s)&(pf_data['持仓日期']==d)]
            pf_cin[s][d]=data_sub1['当日卖出金额'].sum()
            pf_cout[s][d]=data_sub1['当日买入金额'].sum()
            pf_values[s][d]=data_sub1['市值'].sum()
            if data_sub2['市值'].sum()+data_sub2['当日买入金额'].sum()==0:
                pf_weights[s][d] = 0
            else:
                pf_weights[s][d] = (pf_values[s][d]+pf_cout[s][d] / (data_sub2['市值'].sum() + data_sub2['当日买入金额'].sum())
            if td_dates.index(d) >0 and (pf_values[s][td_dates[td_dates.index(d)-1]] + pf_cout[s][d])>0:
                pf_r[s][d] = (pf_values[s][d] + pf_cin[s][d]) / (pf_values[s][td_dates[td_dates.index(d)-1]] + pf_cout[s][d])-1
    return  [pf_weights,pf_r]            

td_dates在哪里声明的,发下

检查一下在if td_dates.index(d)和>0之间是不是多写了空格导致的错误。把该句中的所有空格全部删去,然后在删除的地方再手动输入空格,这样能删掉无效字符。这样试试看能否解决问题。

  if td_dates.index(d) >0 and (pf_values[s][td_dates[td_dates.index(d)-1]] + pf_cout[s][d])>0:

if前面加一个(小括号。

报错原因是:

  File "<ipython-input-135-50dc2a49709c>", line 21
    if td_dates.index(d) >0 and (pf_values[s][td_dates[td_dates.index(d)-1]] + pf_cout[s][d])>0:
                                                                                               ^
SyntaxError: invalid syntax

您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y