python - ValueError: time data does not match format
python - ValueError: time data does not match format
我从 here 下载了我的 CSV 文件 TSLA.csv。它有 header 行和 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: time data "['2010-06-29" does not match format '%Y-%m-%d'
我有 double-checked 格式并检查了这里的其他问题,但这些问题主要是关于错误的格式...我看不到这里的问题。帮助表示赞赏。
好的,我认为问题出在这里:
再次查看错误,它显示 "['2010-06-29" does not match data format
。
那是因为您没有尝试单独解析日期,请查看日期周围的双引号。
您正在尝试解析:
['2010-06-29
你的字符串中有一个额外的 ['
把事情搞砸了。
我从 here 下载了我的 CSV 文件 TSLA.csv。它有 header 行和 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: time data "['2010-06-29" does not match format '%Y-%m-%d'
我有 double-checked 格式并检查了这里的其他问题,但这些问题主要是关于错误的格式...我看不到这里的问题。帮助表示赞赏。
好的,我认为问题出在这里:
再次查看错误,它显示 "['2010-06-29" does not match data format
。
那是因为您没有尝试单独解析日期,请查看日期周围的双引号。
您正在尝试解析:
['2010-06-29
你的字符串中有一个额外的 ['
把事情搞砸了。