gpt4 book ai didi

python - pandas csv 阅读器中的日期转换

转载 作者:太空宇宙 更新时间:2023-11-04 10:48:50 24 4
gpt4 key购买 nike

from StringIO import StringIO
import datetime as dt
import pandas as pd

def addtime(temp):
temp = (temp) + (dt.timedelta(hours =16))
return(temp)

data = """\
'12-31-2012',5100, 5200
'01/1/2013',5300,5400"""

tdata = pd.read_csv(StringIO(data),
names = ['date', 'field1', 'field'], index_col = None,
parse_dates =['date'], header= None)

print tdata

old_date = tdata.ix[0,'date']
print 'old date =',old_date
new_date = addtime(old_date)
print 'new date =',new_date

# date field1 field
#0 2012-12-31 00:00:00 5100 5200
#1 2013-01-01 00:00:00 5300 5400
#old date = 2012-12-31 00:00:00
#new date = 2012-12-31 16:00:00

作为 Pandas CSV 阅读器的一部分,我想为每个日期添加 16 小时。但我不知道如何添加一个有效的“parse_dates=”。示例代码正确地执行了操作,只是没有以所需的方式执行。帮助将不胜感激。

最佳答案

使用date_parser 参数。通常,默认为 dateutil.parser.parse,但您可以指定一个自定义函数(例如下面的 addtime),它不仅解析日期字符串,还添加一个timedelta 也是如此。

from StringIO import StringIO
import datetime as dt
import pandas as pd
import dateutil.parser as parser

def addtime(temp):
temp = parser.parse(temp) + dt.timedelta(hours=16)
return temp

data = """\
'12-31-2012',5100, 5200
'01/1/2013',5300,5400"""

tdata = pd.read_csv(StringIO(data),
names = ['date', 'field1', 'field'], index_col = None,
parse_dates =['date'], header= None, date_parser=addtime)

print tdata

产量

                  date  field1  field
0 2012-12-31 16:00:00 5100 5200
1 2013-01-01 16:00:00 5300 5400

关于python - pandas csv 阅读器中的日期转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15465087/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com