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

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

從文件名中檢測模式,然后從右側提取 5 個字符

從文件名中檢測模式,然后從右側提取 5 個字符

紅顏莎娜 2023-02-22 16:06:08
我在 A 目錄中有數千個文件,我想做的是:檢測文件名中帶有“ABC”的任何文件。檢測到后,再提取右側的 5 個字符。例子:34291.daveabc2712144.txteidddvabc24156.mp3beonabcsimple.csv輸出:abc27121abc24156abcsimpl感謝問候
查看完整描述

4 回答

?
森林海

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

你可以使用正則表達式做這樣的事情:


import re

txts = ["34291.daveabc2712144.txt",

        "eidddvabc24156.mp3",

        "beonabcsimple.csv",

        "fABCgfdge.txt"]

for i in txts:

    x = re.findall("abc.{5}", i)

    #if you need to be case insensitive you can do this

    #x = re.findall("abc.{5}", i, re.IGNORECASE)

    if x:

        print(x)


查看完整回答
反對 回復 2023-02-22
?
慕森王

TA貢獻1777條經驗 獲得超3個贊

以下是如何使用該glob模塊。假設所有的abc都是小寫的:


from glob import glob


for file in glob('*abc*'): # For every file that has 'abc' in it

    i = file.find('abc') # Find the index of the 'abc'

    print(file[i:i+8]) # Print out the file name 5 characters from the end of 'abc', or 8 from the start

這樣做的好處是:glob('*abc*')這樣我們就不會首先列出所有'abc'文件,只列出名稱中包含的文件。


查看完整回答
反對 回復 2023-02-22
?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

>>> s = '34291.daveabc2712144.txt'

>>> s[(start := s.index('abc')): start + 8] 

'abc27121'

假設海象運算符'abc'可以找到并且需要 Python 3.8+。


在我看來,這樣一個簡單的任務不需要正則表達式。


查看完整回答
反對 回復 2023-02-22
?
白衣染霜花

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

您可以使用正則表達式:


abc.{5}

在Python:


import re


strings = ["34291.daveabc2712144.txt", "eidddvabc24156.mp3", "beonabcsimple.csv"]


rx = re.compile(r'abc.{5}')


names = [m.group(0) for string in strings for m in [rx.search(string)] if m]

print(names)

請參閱regex101.com 上的演示。



查看完整回答
反對 回復 2023-02-22
  • 4 回答
  • 0 關注
  • 152 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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