• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 219046
            • 排名 - 118

            最新評論

            閱讀排行榜

            評論排行榜

            弱弱的寫了一下,可以自用-_-
              1 #!/usr/bin/env python
              2 
              3 import os
              4 import os.path
              5 import re
              6 import sys
              7 
              8 re_sp = re.compile("/")
              9 max_level = 0x7FFFFFFF
             10 
             11 
             12 def get_dirname(path) :
             13     """
             14     get the dirname by a path
             15     """
             16     global re_sp
             17 
             18     path = os.path.realpath(path)
             19     lst_ret = re_sp.split(path)
             20     if 0 == len(lst_ret) :
             21         return ""
             22     return lst_ret[len(lst_ret)-1]
             23 
             24 
             25 def get_startmark(path, lvl) :
             26     """
             27     get the startmark which will be displayed first
             28     """
             29     global max_level
             30 
             31     new_str = ""
             32     for i in range(lvl) :
             33         new_str += '|'
             34 
             35     if True == os.path.isdir(path) :
             36         if len(os.listdir(path)) > 0 and lvl == max_level:
             37             new_str += "+"
             38         else :
             39             new_str += "-"
             40         for i in range(lvl) :
             41             new_str += ' '
             42     else :
             43         new_str += '|'
             44         for i in range(lvl) :
             45             new_str += ' '
             46     
             47     return new_str
             48 
             49 
             50 def dfs_dir(path, lvl) :
             51     """
             52     deep first search the path
             53     """
             54     global max_level
             55 
             56     new_str = get_startmark(path, lvl)
             57     print "%s%s" % (new_str, get_dirname(path)),
             58 
             59     #check file type
             60     if True == os.path.islink(path) :
             61         print "%s" % "[L]",
             62     if True == os.path.ismount(path) :
             63         print "%s" % "[M]",
             64     if False == os.path.isdir(path) :
             65         print "[%d]" % os.path.getsize(path)    
             66     else :
             67         print ""
             68 
             69     if False == os.path.isdir(path) :
             70         return
             71 
             72     if lvl == max_level :
             73         return
             74 
             75     files = os.listdir(path)
             76     for each_file in files :
             77         new_path = "%s/%s" % (path, each_file)
             78         dfs_dir(new_path, lvl+1)
             79 
             80 
             81 def pytree() :
             82     """
             83     the main function to run
             84     """
             85     global max_level
             86 
             87     argvs = sys.argv
             88     
             89     if 0 == len(argvs) % 2 :
             90         print "Argvs invalid!"
             91         sys.exit(-1)
             92     else :
             93         cur_path = ""
             94 
             95         for tmp_str in argvs :
             96             if tmp_str.startswith("-") :
             97                 if "-i" == tmp_str :
             98                     idx = argvs.index(tmp_str)
             99                     max_level = int(argvs[idx+1])
            100                 if "-p" == tmp_str:
            101                     idx = argvs.index(tmp_str)
            102                     cur_path = os.path.realpath(argvs[idx+1])
            103 
            104         if "" == cur_path :
            105             cur_path = os.getcwd()
            106 
            107         if False == os.path.isdir(cur_path) :
            108             print "Argvs invalid : path not exits!"
            109         else :
            110             print "List Dir : %s" % cur_path
            111             dfs_dir(cur_path, 0)
            112 
            113     
            114 
            115 
            116 if __name__ == "__main__" :
            117     pytree()
            118 


            posted on 2009-03-29 19:56 閱讀(282) 評論(0)  編輯 收藏 引用 所屬分類: Python

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            99久久夜色精品国产网站| 精品久久久无码人妻中文字幕| 久久这里有精品| 久久人人爽人人人人爽AV| 亚洲∧v久久久无码精品| 99999久久久久久亚洲| 性做久久久久久久久久久| 偷窥少妇久久久久久久久| 久久99精品久久久久子伦| 一本久久久久久久| 久久香综合精品久久伊人| 久久精品草草草| 久久无码高潮喷水| 久久久久久狠狠丁香| 亚洲精品WWW久久久久久| 人妻少妇久久中文字幕| 久久国产精品成人免费| 久久无码中文字幕东京热| 精品一久久香蕉国产线看播放| 一本色道久久88综合日韩精品| 国产精品久久一区二区三区| 亚洲精品第一综合99久久| 欧美久久精品一级c片片| 久久久久人妻精品一区二区三区| 狠狠精品久久久无码中文字幕 | 色欲久久久天天天综合网| 国内精品久久久久国产盗摄| 一本色综合网久久| 伊人久久大香线蕉无码麻豆| 久久丝袜精品中文字幕| 国产精品99久久久久久猫咪| 91久久婷婷国产综合精品青草| 精品人妻伦九区久久AAA片69| 欧美亚洲国产精品久久久久| 欧美精品丝袜久久久中文字幕 | 色婷婷综合久久久久中文| 亚洲国产精品无码久久一区二区| 伊人久久精品影院| 国产成人精品综合久久久久| 久久精品视频一| 亚洲AV无码久久精品蜜桃|