月份的周数

2024-04-25 23:35:11 发布

您现在位置:Python中文网/ 问答频道 /正文

pandas(python)是否提供了一种从日期序列中轻松获取当前一周(1:4)的方法?在

data = {'date': ['2014-05-01', '2014-05-01', '2014-05-02', '2014-05-02', '2014-05-02', '2014-05-02', '2014-05-03', '2014-05-03', '2014-05-04', '2014-05-04']}
df = pd.DataFrame(data, columns = ['date'])
df['date']=pd.to_datetime(df['date'])

def week_of_month(dt):
    """ Returns the week of the month for the specified date.
    """
    first_day = dt.replace(day=1)
    dom = dt.day
    adjusted_dom = dom + first_day.weekday()
    return int(ceil(adjusted_dom/7.0))


df ['week']=np.nan
for i in range(len(df)):
    df ['week'][i] =  week_of_month(df.date.iloc[i])

对于短数据集,它可以工作,但对于大数据集,则需要大量资源


Tags: ofthe数据dffordatadatedt
1条回答
网友
1楼 · 发布于 2024-04-25 23:35:11

解决问题:

data = {'date_x': ['2014-05-01', '2014-05-01', '2014-05-02', '2014-05-02', '2014-05-02', '2014-05-02', '2014-05-03', '2014-05-03', '2014-05-04', '2014-05-04']}
df = pd.DataFrame(data, columns = ['date_x'])
df['date']=pd.to_datetime(df['date_x'])

df['first_day_aux']=pd.to_datetime(df['date_x'][0][:8]+'01') 
df['day']=df['date'].dt.day 
df['adjusted_dom']=df['day']+df['first_day_aux'].dt.dayofweek
df['week']=np.int_(np.ceil(df['adjusted_dom']/7.0))

相关问题 更多 >

    热门问题