第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

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

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

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

4 回答

?
森林海

TA貢獻2011條經(jīng)驗 獲得超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)


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

TA貢獻1777條經(jīng)驗 獲得超3個贊

以下是如何使用該glob模塊。假設(shè)所有的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'文件,只列出名稱中包含的文件。


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

TA貢獻1797條經(jīng)驗 獲得超6個贊

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

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

'abc27121'

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


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


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

TA貢獻1796條經(jīng)驗 獲得超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 上的演示。



查看完整回答
反對 回復(fù) 2023-02-22
  • 4 回答
  • 0 關(guān)注
  • 159 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學習伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號