用Python实现Linux tree命令

用Python实现Linux tree命令早就耳闻python功能强大,互联网领域运用广泛,Scrapy爬虫框架、OpenStack云存储架构都是用Python实现的。最近下定决心,开始学习Python。先参考网上的demo写一个小例子,实现linuxtree命令。#!/usr/bin/pythonimportos,sys,stringclassXXXTree:def__init__(self):

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

早就耳闻python 功能强大,互联网领域运用广泛,Scrapy爬虫框架、OpenStack云存储架构都是用Python实现的。最近下定决心,开始学习Python。先参考网上的demo写一个小例子,实现linux tree命令。

#!/usr/bin/python
import os, sys, string

class XXXTree:
    def __init__(self):
        pass

    def printHelp(self, cmd):
        print "Please use the follow cmd"
        print " " + cmd + 'dir'
        print "e.g"
        print " " + cmd + "/root/Kedacom_src"

    def getTree(self, dir, op):
        list = self.getList(dir, 0, op)
        treeList = []
        #遍历文件列表,进行格式化输出处理,将处理后的元素添加到treeList中
        for i in range(1, len(list)):
            fullpath = list[i]
            filename = os.path.basename(fullpath)

            if(fullpath == dir):
                treeList.append(fullpath)
                continue

            path = fullpath.replace(dir, "")
            names = path.split('/')
            name = "|-- " + names[len(names)-1]
            for tmp in range(1, len(names)-1):
                name = " " + name 

            treeList.append(name)

            pos = name.find('&')
            if (pos >= 0):
                j = i-1
                if j >= 0:
                    name = treeList[j]
                    if (name[pos] == '&'):
                        tmp = name.index('|')
                        name = name[0:tmp] + "`" + name[tmp+1:pos]
                        treeList[j] = name

        for i in range(0, len(treeList)):
            print treeList[i]

    #递归获取目录下所有的文件,除去隐形文件
    def getList(self, dir, layer, op):
        list = [ ]
        if (layer == 0):list.append(dir)
        #对目录下的文件列表进行排序
        files = sorted(os.listdir(dir))
        for file in files:
            if (file[0] == '.'):
                continue
            file = os.path.join(dir, file)
            if os.path.isdir(file):
                list.append(file)
                list += self.getList(file, layer+1, op)
            elif (op == '-d'):
                pass
            else:
                list.append(file)
        newfile = file + '&'
        pos = list.index(file)
        list[pos] = newfile
        return list

if (len(sys.argv) < 2):
    t = XXXTree()
    t.printHelp(sys.argv[0])

else:
    t = XXXTree()

    dir = None
    if (len(sys.argv) == 2):dir = sys.argv[1]

    op = None
    if (len(sys.argv) == 3):
        op = sys.argv[1]
        dir = sys.argv[2]

    t.getTree(dir, op)

运行结果

脚本运行结果

系统命令tree运行结果

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/164147.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月24日 下午11:36
下一篇 2022年7月24日 下午11:36


相关推荐

  • 技术相关连接

    技术相关连接JavaScript:JavaScript ES6中export及export default的区别 :https://blog.csdn.net/zhou_xiao_cheng/article/details/52759632Vue:从vue新建页面过程看vue项目文件调用关系 :https://blog.csdn.net/weixin_43236610/article…

    2022年6月13日
    26
  • 文件系统的类型「建议收藏」

    文件系统的类型「建议收藏」文件系统类型:ext2:早期linux中常用的文件系统ext3:ext2的升级版,带日志功能RAMFS:内存文件系统,速度很快NFS:网络文件系统,由SUN发明,主要用于远程文

    2022年7月3日
    25
  • 性能干翻235B,单卡私有化部署OpenClaw

    性能干翻235B,单卡私有化部署OpenClaw

    2026年3月13日
    1
  • 第一范式第二范式第三范式「建议收藏」

    第一范式第二范式第三范式「建议收藏」关系数据库中的关系必须满足一定的要求。满足不同程度要求的为不同范式。数据库的设计范式是数据库设计所需要满足的规范。只有理解数据库的设计范式,才能设计出高效率、优雅的数据库,否则可能会设计出错误的数据库. 目前,主要有六种范式:第一范式、第二范式、第三范式、BC范式、第四范式和第五范式。满足最低要求的叫第一范式,简称1NF。在第一范式基础上进一步满足一些要求的为第二范式,简称2NF。其余依此类推

    2022年5月10日
    44
  • vue上传图片组件编写

    vue上传图片组件编写点击打开源码编写一个vue上传图片组件:1.首先得有一个[type=file]文件标签并且隐藏,changge事件来获取图片:2.触发隐藏的文件标签:(通过原生的click来触发)document.getElementById(‘upload_file’).click()3.获取file文件里面的值方法:fileChange($event)fileCha

    2022年6月24日
    27
  • 分别以递归调用和迭代的方法求数列_迭代算法和递归算法

    分别以递归调用和迭代的方法求数列_迭代算法和递归算法对于数列,递归和迭代的联系非常紧密。a0,a1,a2,…,an−1,ana_0,a_1,a_2,…,a_{n-1},a_na0​,a1​,a2​,…,an−1​,an​数列就是一串数字,数列来源于生活,有用的数列中蕴含着规则。要完整描述一个数列,方法有二:通项公式an=f(n)a_n=f(n)an​=f(n)递推公式其中通项公式是最一般的情况。由通项公式可以求得任意一…

    2025年9月3日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号