我有一个字符串,它是全年,后面跟着一年中的ISO周(所以有些年份有53周,因为周数从一年中第一个完整的周开始)。我想使用pandas.to_datetime()
将其转换为datetime
对象。所以我做了:
pandas.to_datetime('201145', format='%Y%W')
并返回:
Timestamp('2011-01-01 00:00:00')
这是不对的。或者如果我尝试:
pandas.to_datetime('201145', format='%Y%V')
它告诉我CCD_ 3是一个坏指令。
我做错了什么?
我认为以下问题对您有用:反转日期.iisocalender()
使用该问题中提供的功能,这就是我将如何进行的:
import datetime
import pandas as pd
def iso_year_start(iso_year):
"The gregorian calendar date of the first day of the given ISO year"
fourth_jan = datetime.date(iso_year, 1, 4)
delta = datetime.timedelta(fourth_jan.isoweekday()-1)
return fourth_jan - delta
def iso_to_gregorian(iso_year, iso_week, iso_day):
"Gregorian calendar date for the given ISO year, week and day"
year_start = iso_year_start(iso_year)
return year_start + datetime.timedelta(days=iso_day-1, weeks=iso_week-1)
def time_stamp(yourString):
year = int(yourString[0:4])
week = int(yourString[-2:])
day = 1
return year, week, day
yourTimeStamp = iso_to_gregorian( time_stamp('201145')[0] , time_stamp('201145')[1], time_stamp('201145')[2] )
print yourTimeStamp
然后为您的值运行该函数,并将它们作为日期-时间对象附加到数据帧中。
我从你指定的字符串中得到的结果是:
2011-11-07