-1
我期待通过从网络中提取一系列数据的循环附加各种数据帧。函数ratios_funda
由它自己的工作正确,但我没有找到一种方法来根据不同的代价来循环它,并将它们一个接一个地追加在空dataframe
。这是代码。追加数据帧时挣扎
import pandas as pd
cartera = ['FB.O', 'SAN.MC','TRE.MC', 'BBVA.MC']
def ratios_funda(x):
rat1=x[2].loc[[1,7,8,10],:]
rat2=x[3].loc[[1,5],:]
rat3=x[5].loc[[1,2,4,5],:]
rat5=x[7].loc[[5,6],:]
rat6=x[8].loc[[1,7],:]
rats=[rat1,rat2,rat3,rat5,rat6]
df=pd.concat([df.set_index(df.columns[0]) for df in rats])
df.index.names=['Fundam ratios']
df.rename(columns={1:'Company',2:'Industry',3:'Sector'}, inplace=True)
df.index = df.index.str.strip()
return df
def resultados():
dataframe=pd.DataFrame()
for titulos in cartera:
ruta=pd.read_html('http://www.reuters.com/finance/
stocks/financialHighlights?symbol='+str(titulos),flavor='html5lib')
if dataframe.empty:
dataframe= ratios_funda(ruta)
else:
dataframe=pd.concat([dataframe, ratios_funda(ruta)],axis=1)
return dataframe
print(resultados())
它看起来像不循环。
它不起作用? – IanS
我发现的问题是试图用不同的'ruta'循环第一个函数,并在'dataframe'中将它们追加到另一个之后。顺便说一句,感谢你的版本LanS – ge00rge
代码看起来很好乍一看。你有错误信息吗? – IanS