使用Pandas将字符串格式化为日期时间-指令有问题



我有一个字符串,它是全年,后面跟着一年中的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

相关内容

  • 没有找到相关文章

最新更新