4 回答

TA貢獻1982條經驗 獲得超2個贊
您可以使用str.split():
path = 's3://tester/test.pdf'
print(path.split('/', 3)[-1])
輸出:
test.pdf
更新:使用正則表達式:
import re
path = 's3://tester/test.pdf'
print(re.split('/',path,3)[-1])
輸出:
test.pdf

TA貢獻1712條經驗 獲得超3個贊
你試過嗎.replace?
你可以這樣做:
string = "s3://tester/test.pdf"
string = string.replace("s3://tester/", "")
print(string)
這將替換"s3://tester/"為空字符串""
或者,您可以使用.split而不是.partition
您也可以嘗試:
string = "s3://tester/test.pdf"
string = "/".join(string.split("/")[3:])
print(string)

TA貢獻1824條經驗 獲得超5個贊
請查看更新
原始 使用內置re
模塊。
p = re.search(r'(?<=s3:\/\/tester\/).+', s).group()
該模式使用后視來跳過您希望忽略的部分并匹配它后面的任何和所有字符,直到整個字符串被消耗,將匹配的組返回給變量以供進一步處理p
。
此代碼適用于遵循s3://tester/
您在問題中提供的顯式模式的任何長度路徑。
更新
剛看到更新呃。
在這件事上弄錯了,我的錯。
re
無論 S3 變量如何,下面的方法都應該有效,返回/
字符串中第三個之后的所有內容。
p = ''.join(re.findall(r'\/[^\/]+', s)[1:])[1:]
添加回答
舉報