亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

正則表達式以中間日期搜索文件

正則表達式以中間日期搜索文件

慕少森 2021-05-12 17:22:03
我正在嘗試創建一個正則表達式,以匹配中間有日期的文件:文件名看起來像這樣"Weekly Score 07.27.2018 Report.csv" "Weekly Score 08.03.2018 Report.csv"該文件夾可以有多個這樣的文件,我想用此模式匹配任何文件。我正在服務器上為此編寫python代碼。
查看完整描述

3 回答

?
拉風的咖菲貓

TA貢獻1995條經驗 獲得超2個贊

使用(0?[1-9] | 1 [012])。(0?[1-9] | [12] [0-9] | 3 [01])。\ d {4}:


import re


files = ["Weekly Score 07.27.2018 Report.csv", "Weekly Score 08.03.2018 Report.csv"]

result = []


for filename in files:

    m = re.search(r"\s(0?[1-9]|1[012])\.(0?[1-9]|[12][0-9]|3[01])\.\d{4}\s", filename)

    if m:

        result.append(m.group())


print(result)

(0?[1-9]|1[012]) -個月(從01到12)

(0?[1-9]|[12][0-9]|3[01]) -天(從01到31)。

\d{4} - 年。


查看完整回答
反對 回復 2021-05-25
?
隔江千里

TA貢獻1906條經驗 獲得超10個贊

您不應該使用正則表達式來匹配日期時間,因為這可能導致誤報。


使用獲取文件glob,對其進行迭代,并使用datetime.datetime.strptime空格分隔的第三字段檢查日期時間模式:


import glob

import datetime


files = glob.iglob('Weekly Score * Report.csv')  # Make necessary changes

                                                 # on the pattern, if you want

for file_name in files:

    try:

        datetime.datetime.strptime(file_name.split()[2], '%m.%d.%Y')

    except ValueError:

        continue

    # Matched; do stuffs

    print(file_name)

例子:


In [960]: files = ["Weekly Score 07.27.2018 Report.csv", "Weekly Score 08.03.2018 Report.csv", "Weekly Score 15.23.2018 Report.csv"]


In [961]: for file_name in files:

     ...:     try:

     ...:         datetime.datetime.strptime(file_name.split()[2], '%m.%d.%Y')

     ...:     except ValueError:

     ...:         continue

     ...:     print(file_name)

     ...: 

     ...:         

Weekly Score 07.27.2018 Report.csv

Weekly Score 08.03.2018 Report.csv


查看完整回答
反對 回復 2021-05-25
  • 3 回答
  • 0 關注
  • 121 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號