亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何從熊貓中的一系列字符串中提取小時和分鐘

如何從熊貓中的一系列字符串中提取小時和分鐘

ibeautiful 2023-04-25 16:50:38
幾個小時以來,我一直被這個看似簡單的問題所困擾。我想將以下字符串轉換為分鐘。(如果可以的話,或者小時和分鐘)。foo['stringtime'] = pd.Series(['1 hour and 59 minutes','2 hours', np.nan, '38 minutes', '4 hours and 31 minutes'])#What I've tried:foo['stringtime'] = foo['stringtime'].str.replace(r'hours?','').str.replace(' minutes','').str.split(' and ')然而,這會'2 hours'造成一種情況'38 minutes'['2']['38']#What I would like to happen:foo.head()output:119120NaN (or 0)38271有什么漂亮優雅的 pythonic 方法可以做到這一點嗎?
查看完整描述

2 回答

?
守著一只汪

TA貢獻1872條經驗 獲得超4個贊

嘗試使用正則表達式。


前任:


import re


def p_time(val):

    try:

        t = 0

        h = re.search(r"(\d+) hour(s)?", val)

        if h:

            t += int(h.group(1)) * 60

        m = re.search(r"(\d+) minute(s)?", val)

        if m:

            t += int(m.group(1))

        return t

    except:

        pass

    return 0


s = pd.Series(['1 hour and 59 minutes','2 hours', np.nan, '38 minutes', '4 hours and 31 minute'])

print(s.apply(p_time).astype(int))

輸出:


0    119

1    120

2      0

3     38

4    271

dtype: int32


查看完整回答
反對 回復 2023-04-25
?
慕無忌1623718

TA貢獻1744條經驗 獲得超4個贊

另一種方法可能只是用于numexpr評估數值方程:


import numexpr


foo = pd.Series(['1 hour and 59 minutes','2 hours', np.nan, '38 minutes', '4 hours and 31 minutes'])


(foo.str.replace(r' hours?','*60').str.replace(' minutes','').str.replace(' and ', '+')

    .fillna('0').apply(numexpr.evaluate))

輸出:


0    119

1    120

2      0

3     38

4    271


查看完整回答
反對 回復 2023-04-25
  • 2 回答
  • 0 關注
  • 137 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號