编写一个 Python 程序来过滤给定序列中的有效日期


输入 − 假设我们有一个序列,

0 2010-03-12 1 2011-3-1 2 2020-10-10 3 11-2-2

输出 − 然后,序列中有效日期的结果为,

0 2010-03-12 2 2020-10-10

解决方案 1

  • 定义一个序列。

  • 应用 lambda 筛选方法来验证序列中的一个模式,

data = pd.Series(l)
result = pd.Series(filter(lambda x:re.match(r"\d{4}\W\d{2}\W\d{2}",x),data))
  • 最后,使用 isin() 函数将结果与该序列进行检查。

示例

让我们看看以下实现来加深理解。

import pandas as pd
import re
l = ['2010-03-12','2011-3-1','2020-10-10','11-2-2']
data = pd.Series(l)
for i,j in data.items():
   if(re.match(r"\d{4}\W\d{2}\W\d{2}",j)):
      print(i,j)

输出

0    2010-03-12
2    2020-10-10
dtype: object

解决方案 2

示例

import pandas as pd
import re
l = ['2010-03-12','2011-3-1','2020-10-10','11-2-2']
data = pd.Series(l)
result = pd.Series(filter(lambda x:re.match(r"\d{4}\W\d{2}\W\d{2}",x),data))
print(data[data.isin(result)])

输出

0    2010-03-12
2    2020-10-10
dtype: object

更新于: 2021-02-24

194 次浏览

开启您的职业生涯

完成课程获取认证

立即开始
广告