- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我从我的 csv 文件中提取了下表
Date,Time,CO2(ppm),CellTemp(c),CellPres(kPa)
10/08/2016,13:21:11,356.89,51.07,99.91
10/08/2016,13:21:12,356.89,51.07,99.91
10/08/2016,13:21:13,356.83,51.07,99.91
我研究了最近几天并尝试了不同的方法让 pandas 将 Date
和 Time
列读取为 datetime
,但我只是做不到。以下是我尝试过的一些方法:
df = pd.read_csv(myfile)
print(df.dtypes)
我得到:
Date object
Time object
CO2(ppm) object
CellTemp(c) object
CellPres(kPa) object
dtype: object
当我尝试时:
df_2 = pd.read_csv(file, parse_dates=[['Date', 'Time']])
print(df_2.dtypes)
我明白了
Date_Time object
CO2(ppm) object
CellTemp(c) object
CellPres(kPa) object
dtype: object
所以,现在 Date
和 Time
在一列中 (11/08/2016 14:06:18
)(我想要的),但未识别为 datetime
。
当我尝试时:
pd.to_datetime(df_2['Date_Time'], format='%d/%m/%Y %H:%M:%S)
我收到错误信息:
File "<ipython-input-31-ace4ed1a0aa9>", line 1
pd.to_datetime(df_2['Date_Time'],format='%d/%m/%Y %H:%M:%S
SyntaxError: EOL while scanning string literal
当我尝试时:
import dateutil.parser
dateutil.parser.parse(df_2['Date_Time'])
我得到(除了一些其他输出)错误信息:
AttributeError: 'Series' object has no attribute 'read'
我还在 Excel 中手动将日期格式更改为 yyyy-mm-dd
并尝试了相同的操作但没有任何更好的结果。我有点认为这一定是我犯的一个非常基本的错误,我是脚本编写的新手,希望得到任何帮助。如果我的问题有格式错误,请道歉我真的试过了。
最佳答案
看起来有一些错误的日期时间或某些值无法转换为日期时间,因此您可以在to_datetime
中添加参数errors='coerce'
将它们转换为 NaT
:
#31.11. does not exist
print (df_2)
Date_Time CO2(ppm) CellTemp(c) CellPres(kPa)
0 10/08/2016 13:21:11 356.89 51.07 99.91
1 10/08/2016 13:21:12 356.89 51.07 99.91
2 31/11/2016 13:21:13 356.83 51.07 99.91
df_2['Date_Time'] = pd.to_datetime(df_2['Date_Time'],
format='%d/%m/%Y %H:%M:%S',
errors='coerce')
print (df_2)
Date_Time CO2(ppm) CellTemp(c) CellPres(kPa)
0 2016-08-10 13:21:11 356.89 51.07 99.91
1 2016-08-10 13:21:12 356.89 51.07 99.91
2 NaT 356.83 51.07 99.91
您还可以通过以下方式检查所有有问题的值:
print (df_2[pd.to_datetime(df_2['Date_Time'],format='%d/%m/%Y %H:%M:%S', errors='coerce').isnull()])
Date_Time CO2(ppm) CellTemp(c) CellPres(kPa)
2 31/11/2016 13:21:13 356.83 51.07 99.91
关于python - pd.to_datetime 或解析日期时间不适用于我的 csv 文件(格式 : dd/mm/yyyy, hh:mm:ss),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38968811/
我正在尝试使用这两种格式解析日期 2014-12-03T10:05:59.5646+08:00: yyyy-MM-dd'T'HH:mm:ss yyyy-MM-dd'T'HH:mm:ssXXX 当我使用
Paypal 返回以下格式的时间戳: yyyy-MM-ddTHH:mm:ssZ 我不知道该怎么办... 如何在 php 中使用本地时区将其转换为 yyyy-MM-dd HH:mm:ss? 我很想pre
我正在使用 Excel 2010 或 Excel 2007 导入包含日期/时间信息的 CSV 文件。我的 CSV 文件中的时间戳具有以下格式:yyyy-mm-dd hh:mm:ss。 (例如:2015
这个问题已经有答案了: Separate Date and Time objects (2 个回答) 已关闭 4 年前。 如何从 SimpleDateFormat("MM/dd/yyyy kk:mm"
这个问题已经有答案了: Java string to date conversion (17 个回答) 已关闭 6 年前。 我需要将日期字符串转换为另一种特定格式。 例如:我有一个日期,可以是 YYY
我想将字符串:24/11/2016 04:30 pm 转换为日期时间值:11/24/2016 04:30 pm。 我的代码为: DateTime date = DateTime.ParseExact(
我想使用 linux 将像“26/11/05 06:00:01,057000000”这样的纪元转换为 yyyy-mm-ddThh:mm:ss? 我曾尝试使用以下脚本但没有成功: echo 26/11/
这个问题在这里已经有了答案: mysql YYYY-MM-DDThh:mm:ss (1 个回答) 关闭 6 年前。 我想上传包含 yyyy-mm-ddThh:mm:ss.sssZ 数据的 csv 文
我在“dd-MM-yyyy HH:mm”中有一个字符串,需要将其转换为格式为日期的对象“yyyy-MM-dd HH:mm”。 下面是我用来转换的代码 oldScheduledDate = "16-05
我有一个数据框(df),它有一个日期列(列名:sale_date),它以以下格式存储数据 dd/mm/yy hh:mm:ss 我正在尝试将其转换为 yyyy-mm-dd hh:mm:ss。尝试了以下但
我的数据库中有日期时间列(格式为 YYYY-mm-dd hh:mm:ss)。 我需要将其转换为 dd-mm-YYYY hh:mm:ss 格式。 我该怎么办?帮助我。 最佳答案 不确定如何在 javas
想知道它们是否代表不同的格式或本质上相同(只是新与旧的演示文稿)。 最佳答案 基于DateTimeFormatter : Offset X and x: This formats the offset
如标题所示,我有一个问题。我需要将 LocalDataTime yyyy-MM-ssThh-mm-ss 解析为 LocalDataTime yyyy-MM-ss hh-mm-ss 但是当我这样做时 S
我想用 mySQL 将我的数据从“yyyy-mm-ddThh-mm-ss.sssZ”转换为“yyyy-mm-dd hh-mm-ss”。 我尝试使用 convert_tz: mysql> SELECT
这个问题在这里已经有了答案: LOAD DATA INFILE easily convert YYYYMMDD to YYYY-MM-DD? (1 个回答) 关闭 6 年前。 我正在尝试将 CSV
我需要更改 string 的日期格式。原始字符串的格式如下: var timeStamp = '2014/07/30 - 14:15:36' 这是我想要实现的日期格式: var timeStampAr
我正在尝试将 yyyy-MM-dd'T'HH:mm:ss.SSSz 格式的日期格式化为 yyyy-mm-dd HH:mm:ss,这应该很容易,但我无法获得它可以工作。 需要解析的日期格式为:2012-
我正在尝试通过传递时间戳作为命令行参数来使用 Synapse 管道运行 Spark 作业。在与 Spark 作业相关的代码运行之前,synapse 正在将字符串命令行参数值从 ISO 格式 2019-
我试过下面的代码: String created_Date = "25-Nov-15 14:23:34"; SimpleDateFormat sdf = new SimpleDateFormat("d
我创建了一个函数,它以与原始格式不同的格式返回日期。基本上,我正在使用此 Select MonthSub('2014-04-10',2)# 语句进行测试,它应该返回2014-02,而不是 2014-0
我是一名优秀的程序员,十分优秀!