我从here下载了我的CSV文件TSLA.csv。它有一个标题行和7列,第一列是日期,其他是浮点数和整数。
我希望能够从中得到一个numpy数组:
import csv
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
import urllib
def bytespdate2num(fmt, encoding="utf-8"):
strconverter = mdates.strpdate2num(fmt)
def bytesconverter(b):
s = b.decode(encoding)
return strconverter(s)
return bytesconverter
with open("TSLA.CSV", "r") as csvfile:
stock_price = csv.reader(csvfile, delimiter=" ")
stock_price = list(stock_price)
date, closep, highp, lowp, openp, volume = np.loadtxt(stock_price,
delimiter = ",",
unpack = True,
skiprows=1,
converters={0: bytespdate2num("%Y-%m-%d")})
麻烦的是,我收到以下错误:
ValueError:时间数据" [' 2010-06-29"不符合格式'%Y-%m-%d'
我已经仔细检查了格式并检查了其他问题,但这些问题主要是错误的格式......我在这里看不到问题。帮助赞赏。
答案 0 :(得分:2)
好的,我相信问题就在这里:
再次查看错误,它显示"['2010-06-29" does not match data format
。
这是因为您不是单独解析日期,而是查看日期周围的双引号。
您正在尝试解析:
['2010-06-29
你的字符串中有一个额外的['
,这会弄乱你的东西。