os.path.commonprefix()和
os.path.relpath()是您的朋友:
>>> print os.path.commonprefix(['/usr/var/log', '/usr/var/security'])
'/usr/var'
>>> print os.path.commonprefix(['/tmp', '/usr/var']) # No common prefix: the root is the common prefix
'/'
因此,您可以测试公共前缀是否是其中一个路径,即如果其中一个路径是共同的祖先:
paths = […, …, …]
common_prefix = os.path.commonprefix(list_of_paths)
if common_prefix in paths:
…
然后可以找到相对路径:
relative_paths = [os.path.relpath(path, common_prefix) for path in paths]
你甚至可以处理两个以上的路径,用这个方法,并测试所有的路径是否都在其中之一。
PS:根据你的路径看起来像,你可能想要执行一些规范化(这是有用的情况下,不知道他们总是以’/’结束,或者如果一些路径是相对的)。相关功能包括os.path.abspath()和os.path.normpath()。
PPS:正如Peter Briggs在评论中提到的,上述简单的方法可能会失败:
>>> os.path.commonprefix(['/usr/var', '/usr/var2/log'])
'/usr/var'
即使/ usr / var不是路径的公共前缀。在调用commonprefix()之前强制所有路径以’/’结束解决这个(特定的)问题。
PPPPS:从Python 3.4开始,我们有pathlib,一个提供一个saner路径操作环境的模块。我想,通过获取每个路径的所有前缀(使用PurePath.parents()),获取所有这些父集的交集,并选择最长的公共前缀,可以获得一组路径的公共前缀。
PPPPPS:Python 3.5引入了一个适当的解决方案,这个问题:os.path.commonpath(),它返回一个有效的路径。