Python 用os和win32api库模仿DOS命令dir (完整实例)

简介: Python 用os和win32api库模仿DOS命令dir (完整实例)

补全了上一篇《Python 使用os库函数listdir() 模拟DOS命令dir》,基本上能够模仿 dir 和 dir/w 的显示结果:


    驱动器 D 中的卷是 文档

    卷的序列号是 109A-0446

    D:\test 的目录

   [.]             [..]            [01]            01.py           [02]            

   02.py           [03]            

                  2 个文件             2,748 字节

                  5 个目录 315,430,735,872 可用字节

    驱动器 D 中的卷是 文档

    卷的序列号是 109A-0446

    D:\test 的目录

   2021/05/02  23:48    <DIR>          .

   2021/05/02  23:48    <DIR>          ..

   2021/05/02  22:56    <DIR>          01

   2021/04/03  12:09             1,486 01.py

   2021/05/02  22:56    <DIR>          02

   2021/04/03  12:09             1,262 02.py

   2021/05/02  23:48    <DIR>          03

                  2 个文件             2,748 字节

                  5 个目录 315,430,735,872 可用字节

    驱动器 E 中的卷是 数据

    卷的序列号是 109A-0537

    E:\ 的目录

   2021/05/04  23:39    <DIR>          【Download】

   2021/05/04  21:19    <DIR>          【ScannedDoc】

   2021/05/04  21:18         2,410,344 杨程驾驶证证件照.png

                  1 个文件         2,410,344 字节

                  2 个目录 300,126,973,952 可用字节



代码:

import os,time
from win32api import GetVolumeInformation as DiskVolume
from win32api import GetDiskFreeSpaceEx as FreeSpace
def attrib(fn):
    from win32api import GetFileAttributes as attr
    ret=str(bin(attr(fn)))
    del attr
    if ret[-2]=='0':
        return True
    else:
        return False
def pyDir(path=None,para=None):
    if path==None: path=os.getcwd()
    dt=lambda x:time.strftime('%Y/%m/%d  %H:%M   ',time.localtime(x))
    cnCount=lambda str:len([i for i in str if '\u4e00'<=i<='\u9fff'])
    _time=dt(os.path.getmtime(path))
    print(u' 驱动器 '+path[0].upper()+ u' 中的卷是 '+DiskVolume(path[0:2])[0])
    tmp=str(hex(DiskVolume(path[0:2])[1])).upper()
    if tmp[:2]=='0X': tmp=tmp[2:]
    diskVol=tmp[:4]+'-'+tmp[4:]
    print(u' 卷的序列号是',diskVol)
    print('\n '+path+u' 的目录\n')
    if path[-2:]!=':\\'and para!='/w':
        print(_time,'<DIR>'.ljust(14),'.')
        print(_time,'<DIR>'.ljust(14),'..')
    if path[-1]!='\\':
        path+='\\'
    if para==None:
        files=[i for i in os.listdir(path) if attrib(path+i)]
        _time=[dt(os.path.getmtime(path+i)) for i in files]
        _size=[os.path.getsize(path+i) for i in files]
        for i,fname in enumerate(files):
            print(_time[i],'<DIR>'.ljust(14) if os.path.isdir(path+fname) else format(_size[i],',').rjust(14),fname)
    elif para=='/w':
        files=[i for i in os.listdir(path) if attrib(path+i)]
        lenths=max([len(i)+cnCount(i)+2 if os.listdir(path) else len(i)+cnCount(i) for i in os.listdir(path)])
        if lenths<=16:
            fw=16
        elif 16<lenths<=20:
            fw=20
        elif 20<lenths<=40:
            fw=40
        elif lenths>40:
            fw=80
        if path[-2:]!=':\\':
            print('[.]'.ljust(fw),end='')
            print('[..]'.ljust(fw),end='')
        for i,fname in enumerate(files):
            if (i+2)*fw%80==0: print()
            cnCount=lambda str:len([i for i in str if '\u4e00'<=i<='\u9fff'])
            print((fname.ljust(fw-cnCount(fname)) if os.path.isfile(path+fname) else '['+fname+']').ljust(fw-cnCount(fname)),end='')
        print()
    fileSize=format(sum([os.path.getsize(path+i) for i in files if os.path.isfile(path+i)]),',')
    fileCount=len([i for i in files if os.path.isfile(path+i)])
    dirCount=len([i for i in files if os.path.isdir(path+i)])
    if path[-2:]!=':\\':dirCount+=2
    diskSize=format(FreeSpace(path[:2])[0],',')
    print(f'{fileCount} 个文件'.rjust(20),f' {fileSize} 字节'.rjust(20))
    print(f'{dirCount} 个目录'.rjust(20),f'{diskSize} 可用字节'.rjust(20))
    print()
pyDir('D:\\test','/w')
pyDir('D:\\test')
pyDir('E:\\')



dir命令默认是不列出隐藏文件或目录的;如果要列出隐藏的,可以在上述代码找到两处 if attrib(path+i) 删除这个条件掉即可 ,此时相当于命令:dir/a

代码用GetVolumeInformation 、 GetDiskFreeSpaceEx 和 GetFileAttributes求硬盘分区的卷号序列号、剩余空间字节数、文件属性等。


GetVolumeInformation() 返回磁盘卷标信息,返回值是一个5元素的tuple,分别对应:


  TCHAR       lpVolumeNameBuffer[1024];            //硬盘卷标名称   
  DWORD     dwVolumeSerialNumber;                 //序列号   
  DWORD     dwMaximumComponentLength;     //文件名最大长度   
  DWORD     FileSystemFlags;                            //文件系统标志   
  TCHAR       lpFileSystemNameBuffer[1024];    //文件系统名称   



其实序列号转成16进制数后去掉0x标记再在中间插入-字符,就与DOS命令dir显示的一样:如“卷的序列号是 109A-0446”

GetDiskFreeSpaceEx() 返回磁盘可用空间,返回值是一个3元素的tuple,分别对应:

LARGE_INTEGER  lpFreeBytesAvailableToCaller    //调用者可用空间的字节数
LARGE_INTEGER  lpTotalNumberOfBytes              //磁盘总容量的字节数
LARGE_INTEGER  lpTotalNumberOfFreeBytes      //磁盘的可用空间的字节数


GetFileAttributes() 对应DOS命令attrib,可以查看和修改文件或目录的属性。返回值是以下列表中的单个数值或它们任意几个的和都可以。进制转换可得到一个最长为16位的二进制数,各位上0,1就表示是否有对应属性,如返回22即2+4+16表示系统隐藏目录。判断文件或目录是否隐藏,请参见上述代码中自定义函数 attrib(fn)


   1 FILE_ATTRIBUTE_READONLY 只读

   2 FILE_ATTRIBUTE_HIDDEN 隐藏

   4 FILE_ATTRIBUTE_SYSTEM 系统

   16 FILE_ATTRIBUTE_DIRECTORY 目录

   32 FILE_ATTRIBUTE_ARCHIVE 存档

   64 FILE_ATTRIBUTE_DEVICE 保留

   128 FILE_ATTRIBUTE_NORMAL 正常

   256 FILE_ATTRIBUTE_TEMPORARY 临时

   ......之后的不常用,一直到2^15




目录
相关文章
|
2月前
|
JSON 算法 API
Python采集淘宝商品评论API接口及JSON数据返回全程指南
Python采集淘宝商品评论API接口及JSON数据返回全程指南
|
2月前
|
JSON API 数据安全/隐私保护
Python采集淘宝拍立淘按图搜索API接口及JSON数据返回全流程指南
通过以上流程,可实现淘宝拍立淘按图搜索的完整调用链路,并获取结构化的JSON商品数据,支撑电商比价、智能推荐等业务场景。
|
3月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
294 0
|
2月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
288 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
2月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
352 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
2月前
|
Ubuntu API C++
C++标准库、Windows API及Ubuntu API的综合应用
总之,C++标准库、Windows API和Ubuntu API的综合应用是一项挑战性较大的任务,需要开发者具备跨平台编程的深入知识和丰富经验。通过合理的架构设计和有效的工具选择,可以在不同的操作系统平台上高效地开发和部署应用程序。
158 11
|
2月前
|
Cloud Native 算法 API
Python API接口实战指南:从入门到精通
🌟蒋星熠Jaxonic,技术宇宙的星际旅人。深耕API开发,以Python为舟,探索RESTful、GraphQL等接口奥秘。擅长requests、aiohttp实战,专注性能优化与架构设计,用代码连接万物,谱写极客诗篇。
Python API接口实战指南:从入门到精通
|
3月前
|
JSON API 数据安全/隐私保护
Python采集淘宝评论API接口及JSON数据返回全流程指南
Python采集淘宝评论API接口及JSON数据返回全流程指南
|
3月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
321 102
|
3月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
349 104