免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: liaozd
打印 上一主题 下一主题

一堆目录名组成的list,如何保留覆盖范围最大的那几个目录 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2014-01-10 15:31 |只看该作者
本帖最后由 liaozd 于 2014-01-10 17:25 编辑

回复 10# ssfjhh



想法真的很好,很受启发,谢谢。

但是如果是这样['/home', '/home/tmp1/tmp2/']就不行了,我改进了一下
  1. dirs = ['/var/log', '/var/lib', '/library', '/home/tmp1/tmp2/tmp3/tmp3','/home/tmp1/tmp2/tmp3/tmp3/tmp4'
  2.         '/homeland', '/home/tmp1', '/home/tmp1/tmp2', '/home']


  3. uniq = []
  4. for path in dirs:
  5.         i = path
  6.         while i is not '':
  7.                 i = i.rpartition('/')[0]
  8.                 if i in dirs:
  9.                         flag = False
  10.                         break
  11.                 else:
  12.                         flag = True
  13.         if flag is True:
  14.                 uniq.append(path)
  15. print uniq

  16. 输出:['/home', '/library', '/var/lib', '/var/log']
复制代码

论坛徽章:
4
金牛座
日期:2013-10-11 16:12:50卯兔
日期:2014-07-31 09:17:19辰龙
日期:2014-08-08 09:28:02狮子座
日期:2014-09-14 20:32:05
12 [报告]
发表于 2014-01-10 17:48 |只看该作者
本帖最后由 ssfjhh 于 2014-01-10 17:57 编辑

我再试着改进一下。
  1. dirs = ['/var/log', '/var/lib', '/library', '/home/tmp1/tmp2/tmp3/tmp3','/home/tmp1/tmp2/tmp3/tmp3/tmp4',
  2.         '/homeland', '/home/tmp1', '/home/tmp1/tmp2', '/home']

  3. uniq = []
  4. for path in dirs:
  5.     i = path
  6.     while i:
  7.         i = i.rpartition('/')[0]
  8.         if i in dirs:
  9.             break
  10.     else:
  11.         uniq.append(path)
  12. print(uniq)
复制代码

论坛徽章:
4
金牛座
日期:2013-10-11 16:12:50卯兔
日期:2014-07-31 09:17:19辰龙
日期:2014-08-08 09:28:02狮子座
日期:2014-09-14 20:32:05
13 [报告]
发表于 2014-01-10 19:59 |只看该作者
  1. dirs = ['/var/log', '/var/lib', '/library', '/home/tmp1/tmp2/tmp3/tmp3','/home/tmp1/tmp2/tmp3/tmp3/tmp4', '/homeland', '/home/tmp1', '/home/tmp1/tmp2', '/home']

  2. def parents(dirs):
  3.     if '/' in dirs:
  4.         return ['/']

  5.     if '' in dirs:
  6.         dirs.remove('')
  7.     uniq = []
  8.     for path in dirs:
  9.         i = path
  10.         while i:
  11.             i = i.rpartition('/')[0]
  12.             if i in dirs:
  13.                 break
  14.         else:
  15.             uniq.append(path)
  16.     return uniq

  17. print(parents(dirs))
复制代码

论坛徽章:
0
14 [报告]
发表于 2014-01-11 00:02 |只看该作者
回复 13# ssfjhh


    这个好!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP