2017-04-25 39 views
-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()) 

它看起来像不循环。

+0

它不起作用? – IanS

+0

我发现的问题是试图用不同的'ruta'循环第一个函数,并在'dataframe'中将它们追加到另一个之后。顺便说一句,感谢你的版本LanS – ge00rge

+0

代码看起来很好乍一看。你有错误信息吗? – IanS

回答

1

问题出在for循环中有return

def resultados(): 
    dataframe=pd.DataFrame() 
    for titulos in cartera: 
     ruta=pd.read_html('your url here') 
     if dataframe.empty: 
      dataframe= ratios_funda(ruta) 
     else: 
      dataframe=pd.concat([dataframe, ratios_funda(ruta)],axis=0) 
    return dataframe 
0

这不是代码的问题,这个问题是不是所有的行情是结构性的HTML同样的方式,这就是为什么我有不同的结果。谢谢大家的帮助!