如何解决如何在python中使用正则表达式来获取两个字符之间的字符串?
| 我将其作为输入 内容= \'abc.zip \'\\ n 我要从中取出abc。我该如何在python中使用正则表达式呢? 编辑: 不,这不是作业问题。我正在尝试使某些东西自动化,并且在某个时候卡住了,这样我就可以使通用自动化成为我拥有的任何zip文件。os.system(\'python unzip.py -z data/ABC.zip -o data/\')
提取zip文件后,将其解压缩。
我计划使其通用,方法是从放置zip文件的目录中获取文件名,然后将文件名提供给上面规定的语法以将其解压缩
解决方法
如果您试图分解路径的某些部分,则可能会发现os.path模块很有用。它具有漂亮的抽象,具有清晰易懂的语义,易于使用。
, 正如我在评论中所暗示的那样,正则表达式不太可能是完成此工作的最佳工具(除非对该问题有一些人为的限制,否则它比您的示例要复杂得多)。标准的字符串和/或路径库提供应执行的功能。为了更好地说明它们是如何工作的,我将使用下面的ѭ1definition定义:
>>> content = \'abc.def.zip\'
如果是文件,则需要名称和扩展名:
>>> import os.path
>>> filename,extension = os.path.splitext(content)
>>> print filename
abc.def
>>> print extension
.zip
如果是字符串,并且要删除子字符串\'abc \':
>>> noabc = content.replace(\'abc\',\'\')
>>> print noabc
.def.zip
如果您想在每次出现一个周期时将其拆分;
>>> broken = content.split(\'.\')
>>> print broken
[\'abc\',\'def\',\'zip\']
如果它有多个期间,并且您想在第一个或最后一个期间中断它:
>>> broken = content.split(\'.\',1)
>>> print broken
[\'abc\',\'def.zip\']
>>> broken = content.rsplit(\'.\',1)
>>> print broken
[\'abc.def\',\'zip\']
, 编辑:更改了正则表达式以匹配\“ content = \'abc.zip \\ n \'\”而不是字符串“ abc.zip \”。
import re
#Matching for \"content = \'abc.zip\\n\'\"
matches = re.match(\"(?P<filename>.*).zip\\n\'$\",\"content = \'abc.zip\\n\'\")
matches = matches.groupdict()
print matches
#Matching for \"abc.zip\"
matches = re.match(\"(?P<filename>.*).zip$\",\"abc.zip\")
matches = matches.groupdict()
print matches
输出:
{\'filename\': \'abc\'}
这将打印ѭ9before之前所有内容的匹配项。您可以像常规字典一样访问所有内容。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。