python - ValueError:时间数据与格式

时间:2017-09-07 07:58:54

标签: python csv numpy date-conversion

我从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'

我已经仔细检查了格式并检查了其他问题,但这些问题主要是错误的格式......我在这里看不到问题。帮助赞赏。

1 个答案:

答案 0 :(得分:2)

好的,我相信问题就在这里:

再次查看错误,它显示"['2010-06-29" does not match data format。 这是因为您不是单独解析日期,而是查看日期周围的双引号。

您正在尝试解析:

['2010-06-29

你的字符串中有一个额外的[',这会弄乱你的东西。