0

我正在使用 pandas_datareader 返回股票价格。该文档指出 pandas_datareader 返回一个 pandas 数据帧。问题是返回的数据框带有空白列名。这意味着在我重命名该列之前(相信这是真的)不能添加另一列。无论如何,这是我的代码:

from datetime import datetime, timedelta
from pandas import pandas as pd
from pandas_datareader import data, wb
from matplotlib.figure import Figure
from matplotlib.dates import DateFormatter
import matplotlib.pyplot as plt
from matplotlib import style
import datetime as dt 
import numpy as np

style.use('ggplot')
today = dt.date.today()
dtStart = (dt.datetime.strptime("2017-01-01", '%Y-%m-%d'))
dtEnd = (dt.datetime(today.year,today.month,today.day)).isoformat(' ') 

def genGraph(graph_filename):

    dtStart = (dt.datetime.strptime("2015-01-01", '%Y-%m-%d'))
    my_stocks = {'VOD.L'} # Single sumbol.
    # my_stocks = {'VOD.L', {'BP.L'}} # Test multiple symbols.

    main_df = pd.DataFrame()
    df = pd.DataFrame()

    for sym in my_stocks:

        if main_df.empty:
            main_df = (data.get_data_google(sym, dtStart)['Close'])
            main_df.rename(columns = {'' : 'X'}, inplace=True)

            print(main_df.head())

        else:
            main_df = main_df.join((data.get_data_google(sym, dtStart)['Close']), how='outer')
            print(main_df)
    else:
        print('')    
    print(main_df.tail())
    return True
genGraph('OK')

这当前返回: 一个符号

两个符号

我尝试了各种方法,但似乎无法重命名带有价格的列。我还尝试重命名日期列并将其作为索引。没运气!我想知道将数据粘贴到表中然后将其取回是否更好。对于简单的操作,Pandas 数据框似乎过于复杂。

我有 python 3.5.3 和最新的熊猫。

4

1 回答 1

0

评论中发布的 AttributeError 很重要——你有一个 Series,相当于一个列,而不是 DataFrame。

main_df.to_frame()

将返回一个数据框,然后您可以重命名其中的列并添加新列。

于 2017-05-11T15:41:21.720 回答