编写一个 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
广告