来自 Pandas DataFrame 的烛台图中的重叠日期
Overlapping Dates in Candlestick Plot from a Pandas DataFrame
我有一个 pandas 数据帧输出如下
Open High Low Close
2016-06-01 69.60 70.20 69.44 69.76
2016-06-02 70.00 70.15 69.45 69.54
2016-06-03 69.51 70.48 68.62 68.91
2016-06-04 69.51 70.48 68.62 68.91
2016-06-05 69.51 70.48 68.62 68.91
2016-06-06 70.49 71.44 69.84 70.11
我使用以下代码制作烛台图:
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.ticker as mticker
from matplotlib.finance import candlestick_ohlc
import matplotlib.dates as mdates
import datetime as dt
#Reset the index to remove Date column from index
df_ohlc = df.reset_index()
#Naming columns
df_ohlc.columns = ["Date","Open","High",'Low',"Close"]
#Converting dates column to float values
df_ohlc['Date'] = df_ohlc['Date'].map(mdates.date2num)
#Making plot
fig = plt.figure()
ax1 = plt.subplot2grid((6,1), (0,0), rowspan=6, colspan=1)
#Converts raw mdate numbers to dates
ax1.xaxis_date()
plt.xlabel("Date")
print(df_ohlc)
#Making candlestick plot
candlestick_ohlc(ax1,df_ohlc.values,width=1, colorup='g', colordown='k',alpha=0.75)
plt.ylabel("Price")
plt.legend()
plt.show()
我得到了烛台图,但日期重叠,我想知道如何解决这个问题?另外我想知道为什么图例没有出现
以下代码解决了数据重叠问题
fig.autofmt_xdate()
您可以通过添加来旋转日期:
for label in ax1.xaxis.get_ticklabels():
label.set_rotation(45)
高于您的 plt.show()
Pandas 如果您要添加移动平均线,
也会为您执行此操作:
df_ohlc['10MA'] = pd.rolling_mean(ohlc['close'], 10)
df_ohlc['10MA'].plot(ax=ax1, label = '10MA')
据我所知,您没有看到图例,因为烛台图表已被理解并且不需要标记。但是,如果您要添加移动平均线,它的 'label = 10MA' 会出现在图例中。
我希望这对您有所帮助,因为它已经很晚了。我在寻找其他帮助时遇到了这个 post。
我有一个 pandas 数据帧输出如下
Open High Low Close
2016-06-01 69.60 70.20 69.44 69.76
2016-06-02 70.00 70.15 69.45 69.54
2016-06-03 69.51 70.48 68.62 68.91
2016-06-04 69.51 70.48 68.62 68.91
2016-06-05 69.51 70.48 68.62 68.91
2016-06-06 70.49 71.44 69.84 70.11
我使用以下代码制作烛台图:
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.ticker as mticker
from matplotlib.finance import candlestick_ohlc
import matplotlib.dates as mdates
import datetime as dt
#Reset the index to remove Date column from index
df_ohlc = df.reset_index()
#Naming columns
df_ohlc.columns = ["Date","Open","High",'Low',"Close"]
#Converting dates column to float values
df_ohlc['Date'] = df_ohlc['Date'].map(mdates.date2num)
#Making plot
fig = plt.figure()
ax1 = plt.subplot2grid((6,1), (0,0), rowspan=6, colspan=1)
#Converts raw mdate numbers to dates
ax1.xaxis_date()
plt.xlabel("Date")
print(df_ohlc)
#Making candlestick plot
candlestick_ohlc(ax1,df_ohlc.values,width=1, colorup='g', colordown='k',alpha=0.75)
plt.ylabel("Price")
plt.legend()
plt.show()
我得到了烛台图,但日期重叠,我想知道如何解决这个问题?另外我想知道为什么图例没有出现
以下代码解决了数据重叠问题
fig.autofmt_xdate()
您可以通过添加来旋转日期:
for label in ax1.xaxis.get_ticklabels():
label.set_rotation(45)
高于您的 plt.show()
Pandas 如果您要添加移动平均线,
也会为您执行此操作:df_ohlc['10MA'] = pd.rolling_mean(ohlc['close'], 10)
df_ohlc['10MA'].plot(ax=ax1, label = '10MA')
据我所知,您没有看到图例,因为烛台图表已被理解并且不需要标记。但是,如果您要添加移动平均线,它的 'label = 10MA' 会出现在图例中。
我希望这对您有所帮助,因为它已经很晚了。我在寻找其他帮助时遇到了这个 post。