gpt4 book ai didi

python - 如何迭代具有混合数据类型值的 DF[ 'column']?

转载 作者:太空宇宙 更新时间:2023-11-04 02:17:31 27 4
gpt4 key购买 nike

我导入了一个 excel 文件,但在 pandas 迭代方面遇到了问题。导入后的数据如下所示。

Acct            Time        Typ     Name   
01/02/2018 NaN NaN NaN
52 07:58:34 1 John
53 07:58:35 1 Jack
54 07:58:35 1 Ron
55 07:58:35 1 Lux
01/03/2018 NaN NaN NaN
79 12:39:25 1 Mike
01/06/2018 NaN NaN NaN
371 12:15:47 1 Eric
422 17:07:33 1 Shawn
01/07/2018 NaN NaN NaN
492 12:43:54 1 George

我想遍历第一列 ("Acct") 的字符串,检查它是 date 还是 number

我在新数据框中创建了一个附加列,并尝试填充日期字段,但几乎没有出现系列错误。

期望这样的输出:

Date_New        Acct        Time        Typ     Name 

01/02/2018 52 07:58:34 1 John
01/02/2018 53 07:58:35 1 Jack
01/02/2018 54 07:58:35 1 Ron
01/02/2018 55 07:58:35 1 Lux
01/03/2018 79 12:39:25 1 Mike
01/06/2018 371 12:15:47 1 Eric
01/06/2018 422 17:07:33 1 Shawn
01/07/2018 492 12:43:54 1 George

如果有人能给我一些指导,我将不胜感激,因为我是 pandas 的新手。

最佳答案

我建议不要迭代,而是使用 pandas 函数。要找到正确的日期,您可以使用 pd.to_datetimeAcct 列转换为正确的日期。 ,并使用参数 errors = 'coerce'。非日期将变为 null (NaT)。然后,使用 ffill 用正确的日期向前填充该列。 , 并通过索引去掉 Time, TypName 列都是 NaN 的列。最后你可以重新排序你的列:

# Find proper dates, create new column:
df['Date_New'] = pd.to_datetime(df['Acct'], errors='coerce')
# Fill non-valid dates:
df['Date_New'].ffill(inplace=True)
# Get rid of `NaN` rows:
df = df[~df[['Time','Typ', 'Name']].isnull().all(1)]
# Reorder Columns
df = df[['Date_New', 'Acct', 'Time', 'Typ', 'Name']]

>>> df
Date_New Acct Time Typ Name
1 2018-01-02 52 07:58:34 1.0 John
2 2018-01-02 53 07:58:35 1.0 Jack
3 2018-01-02 54 07:58:35 1.0 Ron
4 2018-01-02 55 07:58:35 1.0 Lux
6 2018-01-03 79 12:39:25 1.0 Mike
8 2018-01-06 371 12:15:47 1.0 Eric
9 2018-01-06 422 17:07:33 1.0 Shawn
11 2018-01-07 492 12:43:54 1.0 George

进一步说明:

为了便于理解,以下是每一步后的结果:

>>> df['Date_New'] = pd.to_datetime(df['Acct'], errors='coerce')
>>> df
Acct Time Typ Name Date_New
0 01/02/2018 NaN NaN NaN 2018-01-02
1 52 07:58:34 1.0 John NaT
2 53 07:58:35 1.0 Jack NaT
3 54 07:58:35 1.0 Ron NaT
4 55 07:58:35 1.0 Lux NaT
5 01/03/2018 NaN NaN NaN 2018-01-03
6 79 12:39:25 1.0 Mike NaT
7 01/06/2018 NaN NaN NaN 2018-01-06
8 371 12:15:47 1.0 Eric NaT
9 422 17:07:33 1.0 Shawn NaT
10 01/07/2018 NaN NaN NaN 2018-01-07
11 492 12:43:54 1.0 George NaT

>>> df['Date_New'].ffill(inplace=True)
>>> df
Acct Time Typ Name Date_New
0 01/02/2018 NaN NaN NaN 2018-01-02
1 52 07:58:34 1.0 John 2018-01-02
2 53 07:58:35 1.0 Jack 2018-01-02
3 54 07:58:35 1.0 Ron 2018-01-02
4 55 07:58:35 1.0 Lux 2018-01-02
5 01/03/2018 NaN NaN NaN 2018-01-03
6 79 12:39:25 1.0 Mike 2018-01-03
7 01/06/2018 NaN NaN NaN 2018-01-06
8 371 12:15:47 1.0 Eric 2018-01-06
9 422 17:07:33 1.0 Shawn 2018-01-06
10 01/07/2018 NaN NaN NaN 2018-01-07
11 492 12:43:54 1.0 George 2018-01-07

>>> df = df[~df[['Time','Typ', 'Name']].isnull().all(1)]
>>> df
Acct Time Typ Name Date_New
1 52 07:58:34 1.0 John 2018-01-02
2 53 07:58:35 1.0 Jack 2018-01-02
3 54 07:58:35 1.0 Ron 2018-01-02
4 55 07:58:35 1.0 Lux 2018-01-02
6 79 12:39:25 1.0 Mike 2018-01-03
8 371 12:15:47 1.0 Eric 2018-01-06
9 422 17:07:33 1.0 Shawn 2018-01-06
11 492 12:43:54 1.0 George 2018-01-07

关于python - 如何迭代具有混合数据类型值的 DF[ 'column']?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52304546/

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