首页 > 解决方案 > 如何在 python 中编写正则表达式来识别字符串中的日期

问题描述

在此作业中,所需的输入采用以下格式:

Regular: 16Mar2009(mon), 17Mar2009(tues), 18Mar2009(wed) ...

Reward: 26Mar2009(thur), 27Mar2009(fri), 28Mar2009(sat)

常规或奖励是客户类型的名称。我像这样分隔这个字符串。

entry_list = input.split(":") #input is a variable  
client = entry_list[0] # only Regular or Reward  
dates = entry_list[1] # only dates  
days = dates.split(",")       

但是现在我需要在天数列表中计算工作日或周末天数:

days = [' 16Mar2009(mon)', ' 17Mar2009(tues)', ' 18Mar2009(wed)']    

当是星期一星期三星期四星期五,都算作工作日,我需要知道输入有多少个工作日。

当它是星期六太阳必须算作周末,我需要知道输入有多少个周末。

如何在python中编写一个正则表达式来搜索这个列表中的所有工作日和周末并计算它们,将工作日和周末的数量放在两个不同的计数器中?

编辑

我编写了这个函数来检查日期是否为写入格式,但它不起作用:

def is_date_valid(date):
    date_regex = re.compile(r'(?:\d{1,2}[A-Za-z]{3}\d{4}\([A-Za-z]{3}\),\s+){2}\d{1,2}[A-Za-z]{3}\d{4}\([A-Za-z]{3}\)$')
    m = date_regex.search(date)

m 只返回 None

标签: pythonregexsearchbuilt-infindall

解决方案


你真的不需要正则表达式。您可以直接查找“sat”和“sun”标签,因为您的日期格式相同(即没有大写字母,没有“tue”而不是“tues”等),您不需要概括为图案。只需遍历列表并查找“sat”和“sun”:

import re #if you are using the re

days = [' 16Mar2009(mon)', ' 17Mar2009(tues)', ' 18Mar2009(wed)', ' 18Mar2009(sat)', ' 18Mar2009(sun)']
weekends = 0
weekdays = 0

for day in days:
  if "sat" in day or "sun" in day:  #if re.search( '(sat|sun)', day ): also works
    weekends = weekends+1
  else:
    weekdays = weekdays+1

print(weekends)
print(weekdays)

>>>2
>>>3

如果您需要使用正则表达式,因为这是例如赋值的一部分,那么if语句的这种变体将做到这一点:if re.search( '(sat|sun)', day ): 这并不比仅使用字符串有用太多,因为在这种情况下字符串正则表达式,但是看看如何将多个模式放在一个带有or样式逻辑的正则表达式中很有用,所以我仍然在这里包含它。


推荐阅读