In the store marketing, for many reason, one stock's data can be incomplete:

We can use 'forward fill' and 'backward fill' to fill the gap:

forward fill:

backward fill:

TO do those in code, we can use numpy's 'fillna()' mathod:

http://pandas.pydata.org/pandas-docs/stable/generated/pandas.DataFrame.fillna.html?highlight=fillna#pandas.DataFrame.fillna

"""Fill missing values"""

import numpy as np
import pandas as pd
import matplotlib.pyplot as plt
import os def fill_missing_values(df_data): df_data.fillna(method='ffill', inplace=True)
return df_data.fillna(method='bfill', inplace=True) def symbol_to_path(symbol, base_dir="data"):
"""Return CSV file path given ticker symbol."""
return os.path.join(base_dir, "{}.csv".format(str(symbol))) def get_data(symbols, dates):
"""Read stock data (adjusted close) for given symbols from CSV files."""
df_final = pd.DataFrame(index=dates)
if "SPY" not in symbols: # add SPY for reference, if absent
symbols.insert(0, "SPY") for symbol in symbols:
file_path = symbol_to_path(symbol)
df_temp = pd.read_csv(file_path, parse_dates=True, index_col="Date",
usecols=["Date", "Adj Close"], na_values=["nan"])
df_temp = df_temp.rename(columns={"Adj Close": symbol})
df_final = df_final.join(df_temp)
if symbol == "SPY": # drop dates SPY did not trade
df_final = df_final.dropna(subset=["SPY"]) return df_final def plot_data(df_data):
"""Plot stock data with appropriate axis labels."""
ax = df_data.plot(title="Stock Data", fontsize=2)
ax.set_xlabel("Date")
ax.set_ylabel("Price")
plt.show() def test_run():
"""Function called by Test Run."""
# Read data
symbol_list = ["JAVA", "FAKE1", "FAKE2"] # list of symbols
start_date = "2005-12-31"
end_date = "2014-12-07"
dates = pd.date_range(start_date, end_date) # date range as index
df_data = get_data(symbol_list, dates) # get data for each symbol # Fill missing values
fill_missing_values(df_data) # Plot
plot_data(df_data) if __name__ == "__main__":
test_run()

最新文章

  1. PHP构造方法
  2. python3 异常处理
  3. SwipeRefreshLayout和RecyclerView滑动冲突的解决
  4. Android IOS WebRTC 音视频开发总结(七三)-- 我为什么走上了创业这条不归路?
  5. POJ 3286 How many 0's?(数位DP)
  6. python 面向对象的三大特征之 继承
  7. JDBC 1
  8. php strtotime 和 date 日期操作
  9. 关于C# json转object时报错:XXXXXXXXXX需要标记“"”,但找到“XX”。
  10. tomcat7源代码Bootstrap
  11. hdu1030
  12. Python机器学习笔记 异常点检测算法——Isolation Forest
  13. js的eval代码快速解密
  14. 【腾讯Bugly干货分享】舞动的表情包——浅析GIF格式图片的存储和压缩
  15. C++中const关键字 理解
  16. python基础之删除文件及删除目录的方法-乾颐堂
  17. Andorid Studio 模块化开发相关配置
  18. C# Action
  19. hdu 1561 树形dp+分组背包
  20. php获取开始与结束日期之间所有日期的方法

热门文章

  1. 贰、js的基础(一)
  2. div隐藏但是依然占位置
  3. WebKit.NET-0.5简单应用
  4. [USACO4.2]完美的牛栏The Perfect Stall
  5. BZOJ 3689 异或之 (可持久化01Trie+堆)
  6. python yield 生成器的介绍(转载)
  7. 关于 Error: No PostCSS Config found in 的错误
  8. caioj 1158 欧拉函数
  9. thymeleaf 常用标签
  10. [React] Use React Fragments to make your DOM tree cleaner