ホームページ > バックエンド開発 > Python チュートリアル > Pythonを使用したディレクトリツリー生成の例

Pythonを使用したディレクトリツリー生成の例

WBOY
リリース: 2016-06-16 08:44:43
オリジナル
1477 人が閲覧しました

复制代码 代码如下:

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import os
import optparse

LOCATION_NONE     = 'NONE'
LOCATION_MID      = 'MID'
LOCATION_MID_GAP  = 'MID_GAP'
LOCATION_TAIL     = 'TAIL'
LOCATION_TAIL_GAP = 'TAIL_GAP'

Notations = {
    LOCATION_NONE: '',
    LOCATION_MID: '├─',
    LOCATION_MID_GAP: '│  ',
    LOCATION_TAIL: '└─',
    LOCATION_TAIL_GAP: '    '
}

class Node(object):
    def __init__(self, name, depth, parent=None, location=LOCATION_NONE):
        self.name = name
        self.depth = depth
        self.parent = parent
        self.location = location
        self.children = []

    def __str__(self):
        sections = [self.name]
        parent = self.has_parent()
        if parent:
            if self.is_tail():
                sections.insert(0, Notations[LOCATION_TAIL])
            else:
                sections.insert(0, Notations[LOCATION_MID])
            self.__insert_gaps(self, sections)
        return ''.join(sections)

    def __insert_gaps(self, node, sections):
        parent = node.has_parent()
        # parent exists and parent's parent is not the root node
        if parent and parent.has_parent():
            if parent.is_tail():
                sections.insert(0, Notations[LOCATION_TAIL_GAP])
            else:
                sections.insert(0, Notations[LOCATION_MID_GAP])
            self.__insert_gaps(parent, sections)

    def has_parent(self):
        return self.parent

    def has_children(self):
        return self.children

    def add_child(self, node):
        self.children.append(node)

    def is_tail(self):
        return self.location == LOCATION_TAIL

class Tree(object):
    def __init__(self):
        self.nodes = []

    def debug_print(self):
        for node in self.nodes:
            print(str(node) + '/')

    def write2file(self, filename):
        try:
            with open(filename, 'w') as fp:
                fp.writelines(str(node) + '/\n'
                              for node in self.nodes)
        except IOError as e:
            print(e)
            return 0
        return 1

    def build(self, path):
        self.__build(path, 0, None, LOCATION_NONE)

def __build(self, path, Depth,parent, location):
if os.path.isdir(path):
name = os.path.basename(path)
Node(名前、深さ、親、場所)
self.add_node(node)
ifparent:
parent.add_child(node)

entries = self.list_folder(path)
end_index = len(entries) - 1
for i, enumerate(entries):
childpath = os.path.join(path,entries) )
location = LOCATION_TAIL if i == end_index else LOCATION_MID
self.__build(childpath, Depth + 1, node, location)

def list_folder(self, path):
"""フォルダーのみ。"""
return [d for d in os.listdir(path) if os.path.isdir(os.path.join) (path, d))]
# os.listdir(path) のエントリ:
# childpath = os.path.join(path,entry)
# if os.path.isdir(childpath) :
# 収益エントリ

def add_node(self, node):
self.nodes.append(node)

def _parse_args():
parser = optparse.OptionParser()
parser.add_option(
'-p', '--path', dest='path', action='store' 、type='string',
default='./', help='ツリーを生成するパス [デフォルト: %default]')
parser.add_option(
'-o', ' --out', dest='file', action='store', type='string',
help='結果を保存するファイル [デフォルト: pathname.trees]')
オプション、引数= parser.parse_args()
# 位置引数は無視されます
戻り値のオプション

def main():
options = _parse_args()
path = options.path
os.path.isdir(path) でない場合:
print('%s はディレクトリではありません' % パス)
return 2

path または path == './' でない場合:
filepath = os.path.realpath(__file__) # Linux の場合
path = os.path.dirname(filepath)
Tree = Tree ()
tree.build(path)
#tree.debug_print()
if options.file:
filename = options.file
else:
name = os.path。 Basename(path)
filename = '%s.trees' % name
return Tree.write2file(filename)

if __name__ == '__main__':
import sys
sys.exit(main())

运行效果

复制代码代码如下:

gtest_start/
§─build/
§─lib/
│ └─gtest/
§─output/
│ ├─primer/
│ │ χ─Debug/
│ │ │ ├─lib/
│ │ │ └─obj/
│ │ └─Release/
│ │ ├─lib/
│ │ └─obj /
│ └─考え/
│ til─Debug/
│ │ ├─lib/
│ │ └─obj/
│ └─リリース/
│ っていつ─lib /
│ └─obj/
§─src/
│ §─入門書/
│ └─考察/
§─test/
│ ├─入門書/
│ lux─thoughts/
§─ third_party/
│ └─gtest/
└─tools/
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート