gpt4 book ai didi

python - Pandas :删除日期不符合指定格式的行

转载 作者:太空狗 更新时间:2023-10-30 00:56:06 24 4
gpt4 key购买 nike

在我的数据集中,我有一个日期列,其中的数据是混合格式的。

  • 有些行只有 YYYY(例如 2009)
  • 其他人有 MMM-YY(例如 Jan-08)
  • 还有一些人有完整的日期 MM/DD/YYYY(例如 01/15/2006)

如何删除不遵循格式 MM/DD/YYYY 的条目?我不太确定从哪里开始。

下面,我提供了数据的 .head() 作为 dict

{'Collection Date': {0: '2001',
1: '2002',
2: '2006',
3: '2/19/2006',
4: '2/28/2006'},
'Complete Genome': {0: 'No', 1: 'No', 2: 'No', 3: 'No', 4: 'No'},
'Country': {0: 'Egypt', 1: 'Egypt', 2: 'Egypt', 3: 'Egypt', 4: 'Egypt'},
'Flu Season': {0: '-N/A-', 1: '-N/A-', 2: '-N/A-', 3: '-N/A-', 4: '-N/A-'},
'Host Species': {0: 'IRD:Human',
1: 'IRD:Human',
2: 'IRD:Bird/Avian',
3: 'IRD:Chicken/Avian',
4: 'IRD:Avian'},
'Protein Name': {0: 'NA', 1: 'NA', 2: 'NA', 3: 'NA', 4: 'HA'},
'Segment': {0: 6, 1: 6, 2: 6, 3: 6, 4: 4},
'Segment Length': {0: 1428, 1: 1449, 2: 1441, 3: 1363, 4: 1707},
'Sequence Accession': {0: 'AJ457944',
1: 'AJ457943',
2: 'GU050304',
3: 'GQ184251',
4: 'KF178948'},
'State/Province': {0: '-N/A-',
1: '-N/A-',
2: '-N/A-',
3: '-N/A-',
4: '-N/A-'},
'Strain Name': {0: '(A/Egypt/84/2001(H1N2))',
1: '(A/Egypt/96/2002(H1N2))',
2: 'A/avian/Egypt/920431/2006(H9N2)',
3: 'A/chicken/Egypt/06207-NLQP/2006(H5N1)',
4: 'A/chicken/Egypt/0626/2006'},
'Subtype': {0: 'H1N2', 1: 'H1N2', 2: 'H9N2', 3: 'H5N1', 4: 'H5N1'}}

最佳答案

与其应用正则表达式来匹配 MM/DD/YYYY,如果你的日期只是 YYYY 或 MMM/YYYY 或 MM/DD/YYYY 那么你可以利用 MM/DD/YYYY 是一个字符串的事实长度 10:

In [8]:

import pandas as pd

pd.set_option('display.notebook_repr_html', False)
df = pd.DataFrame({'date':['01/03/1987', '2003', 'Jan-08', '31/01/2010']})
df
Out[8]:
date
0 01/03/1987
1 2003
2 Jan-08
3 31/01/2010

[4 rows x 1 columns]
In [9]:

df.ix[df.date.str.len() !=10]
Out[9]:
date
1 2003
2 Jan-08

[2 rows x 1 columns]

然后你可以只使用 to_datetime :

In [16]:

df1 = df.ix[df.date.str.len() !=10]
df1
Out[16]:
date
1 2003
2 Jan-08

[2 rows x 1 columns]
In [17]:

df1.date = pd.to_datetime(df1.date)
df1
Out[17]:
date
1 2003-01-01 00:00:00
2 2014-01-08 00:00:00

[2 rows x 1 columns]

如果您想使用正则表达式进行过滤,只是为了完整性:

df.ix[~df.date.str.contains('(\d{2})[/](\d{2})[/](\d{4})')]

会起作用,注意 ~ 这是一个否定

关于python - Pandas :删除日期不符合指定格式的行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21556744/

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