跟老齐学Python之折腾一下目录


Posted in Python onOctober 24, 2014

python在安装的时候,就自带了很多模块,我们把这些模块称之为标准库,其中,有一个是使用频率比较高的,就是 os 。这个库中方法和属性众多,有兴趣的看官可以参考官方文档:https://docs.python.org/2/library/os.html,或者在交互模式中,用dir(os)看一看。

>>> import os   #这个动作很重要,不能缺少

>>> dir(os)

['EX_CANTCREAT', 'EX_CONFIG', 'EX_DATAERR', 'EX_IOERR', 'EX_NOHOST', 'EX_NOINPUT', 'EX_NOPERM', 'EX_NOUSER', 'EX_OK', 'EX_OSERR', 'EX_OSFILE', 'EX_PROTOCOL', 'EX_SOFTWARE', 'EX_TEMPFAIL', 'EX_UNAVAILABLE', 'EX_USAGE', 'F_OK', 'NGROUPS_MAX', 'O_APPEND', 'O_ASYNC', 'O_CREAT', 'O_DIRECT', 'O_DIRECTORY', 'O_DSYNC', 'O_EXCL', 'O_LARGEFILE', 'O_NDELAY', 'O_NOATIME', 'O_NOCTTY', 'O_NOFOLLOW', 'O_NONBLOCK', 'O_RDONLY', 'O_RDWR', 'O_RSYNC', 'O_SYNC', 'O_TRUNC', 'O_WRONLY', 'P_NOWAIT', 'P_NOWAITO', 'P_WAIT', 'R_OK', 'SEEK_CUR', 'SEEK_END', 'SEEK_SET', 'TMP_MAX', 'UserDict', 'WCONTINUED', 'WCOREDUMP', 'WEXITSTATUS', 'WIFCONTINUED', 'WIFEXITED', 'WIFSIGNALED', 'WIFSTOPPED', 'WNOHANG', 'WSTOPSIG', 'WTERMSIG', 'WUNTRACED', 'W_OK', 'X_OK', '_Environ', '__all__', '__builtins__', '__doc__', '__file__', '__name__', '__package__', '_copy_reg', '_execvpe', '_exists', '_exit', '_get_exports_list', '_make_stat_result', '_make_statvfs_result', '_pickle_stat_result', '_pickle_statvfs_result', '_spawnvef', 'abort', 'access', 'altsep', 'chdir', 'chmod', 'chown', 'chroot', 'close', 'closerange', 'confstr', 'confstr_names', 'ctermid', 'curdir', 'defpath', 'devnull', 'dup', 'dup2', 'environ', 'errno', 'error', 'execl', 'execle', 'execlp', 'execlpe', 'execv', 'execve', 'execvp', 'execvpe', 'extsep', 'fchdir', 'fchmod', 'fchown', 'fdatasync', 'fdopen', 'fork', 'forkpty', 'fpathconf', 'fstat', 'fstatvfs', 'fsync', 'ftruncate', 'getcwd', 'getcwdu', 'getegid', 'getenv', 'geteuid', 'getgid', 'getgroups', 'getloadavg', 'getlogin', 'getpgid', 'getpgrp', 'getpid', 'getppid', 'getresgid', 'getresuid', 'getsid', 'getuid', 'initgroups', 'isatty', 'kill', 'killpg', 'lchown', 'linesep', 'link', 'listdir', 'lseek', 'lstat', 'major', 'makedev', 'makedirs', 'minor', 'mkdir', 'mkfifo', 'mknod', 'name', 'nice', 'open', 'openpty', 'pardir', 'path', 'pathconf', 'pathconf_names', 'pathsep', 'pipe', 'popen', 'popen2', 'popen3', 'popen4', 'putenv', 'read', 'readlink', 'remove', 'removedirs', 'rename', 'renames', 'rmdir', 'sep', 'setegid', 'seteuid', 'setgid', 'setgroups', 'setpgid', 'setpgrp', 'setregid', 'setresgid', 'setresuid', 'setreuid', 'setsid', 'setuid', 'spawnl', 'spawnle', 'spawnlp', 'spawnlpe', 'spawnv', 'spawnve', 'spawnvp', 'spawnvpe', 'stat', 'stat_float_times', 'stat_result', 'statvfs', 'statvfs_result', 'strerror', 'symlink', 'sys', 'sysconf', 'sysconf_names', 'system', 'tcgetpgrp', 'tcsetpgrp', 'tempnam', 'times', 'tmpfile', 'tmpnam', 'ttyname', 'umask', 'uname', 'unlink', 'unsetenv', 'urandom', 'utime', 'wait', 'wait3', 'wait4', 'waitpid', 'walk', 'write']

在这么多的东西中,本讲只关注os.path,真所谓“弱水三千,只取一瓢”,为什么这么偏爱它呢?因为它和前面已经讲过的文件操作进行配合,就能够随心所欲操作各个地方的文件了(关于文件,请参考:不要红头文件(1)、不要红头文件(2))

关于os.path的属性也不少,依然可以用dir(os.path)查看:

>>> dir(os.path)

['__all__', '__builtins__', '__doc__', '__file__', '__name__', '__package__', '_joinrealpath', '_unicode', '_varprog', 'abspath', 'altsep', 'basename', 'commonprefix', 'curdir', 'defpath', 'devnull', 'dirname', 'exists', 'expanduser', 'expandvars', 'extsep', 'genericpath', 'getatime', 'getctime', 'getmtime', 'getsize', 'isabs', 'isdir', 'isfile', 'islink', 'ismount', 'join', 'lexists', 'normcase', 'normpath', 'os', 'pardir', 'pathsep', 'realpath', 'relpath', 'samefile', 'sameopenfile', 'samestat', 'sep', 'split', 'splitdrive', 'splitext', 'stat', 'supports_unicode_filenames', 'sys', 'walk', 'warnings']

这么多属性,看官可以用help()逐个查看有关信息,并了解其使用方法。下面列出常见的几个使用方法,为看官减轻一点阅读英文的障碍,不过,如果看官英语足够好,请直接看原文档。就像这样:

>>> help(os.path.split)
split(p)

    Split a pathname.  Returns tuple "(head, tail)" where "tail" is

    everything after the final slash.  Either part may be empty.

以下将一些典型举例说明:

特别说明,下面的所有操作,均是进入到如下的目录中进行的。

qw@qw-Latitude-E4300:~/Documents/ITArticles/BasicPython/codes$ pwd

/home/qw/Documents/ITArticles/BasicPython/codes         #当前目录
qw@qw-Latitude-E4300:~/Documents/ITArticles/BasicPython/codes$ python
Python 2.7.6 (default, Nov 13 2013, 19:24:16) 

[GCC 4.6.3] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>>

文件的绝对路径

>>> import os.path

>>> os.path.abspath("225.py")

'/home/qw/Documents/ITArticles/BasicPython/codes/225.py'

文件 225.py 是真实存在上述路径中的,得到了该文件的绝对路径。但是,如果随便提供一个不在这个目录中的文件,又如何?

>>> os.path.isfile("225.py")

True
>>> os.path.isfile("2222.py")

False

>>> os.path.abspath("2222.py")

'/home/qw/Documents/ITArticles/BasicPython/codes/2222.py'

os.path.isfile(path),可以判断path中是否是文件,其实是判断在该路径中,是否存在那个文件,如果存在则返回True,否则False。上面的操作发现 2222.py 这个文件在当前目录下是不存在的,但是,用os.path.abspaht("2222.py")能够返回一个绝对路径并带有这个不存在的文件的文件名。这里不妨理解为,如果要建立这个文件,它即将被放在那个位置。

按照这样理解,还可:

>>> os.path.abspath("/home/qw/kkkkkkkk.kk")

'/home/qw/kkkkkkkk.kk'

分开目录和文件名

>>> pn = os.path.abspath("225.py")

>>> pn

'/home/qw/Documents/ITArticles/BasicPython/codes/225.py'
>>> os.path.split(pn)

('/home/qw/Documents/ITArticles/BasicPython/codes', '225.py')

>>> path, filename = os.path.split(pn)[0], os.path.split(pn)[1]

>>> path

'/home/qw/Documents/ITArticles/BasicPython/codes'

>>> filename

'225.py'

os.paht.split(),参数是目录加文件名,就可以将路径和文件名分开。其实,我看这个功能不是很智能,你看这样

>>> os.path.split("/home/qw")

('/home', 'qw')
>>> os.path.split("/home/qw/")

('/home/qw', '')

它就是将最后一组认为是文件名了,即最后一个/后面的就是文件名,所以第二个实验中,文件名是空了。是不是有点傻呢?

同样,参数中的文件或者目录,不一定是你的电脑中真实存在的,请看:

>>> os.path.split("/foo/python/qiwsir/git.git")

('/foo/python/qiwsir', 'git.git')

只要符合目录书写结构,就可以分解了。

有另外两个属性,是os.path.split()的分别执行,即可以分别获得路径和文件名,这样让操作更简单了。

>>> os.path.dirname("/foo/python/qiwsir/git.git")

'/foo/python/qiwsir'

>>> os.path.basename("foo/python/qiwsir/git.git")

'git.git'

判断

前面稍微提到了os.path.isfile()可以用来判断一个文件是否存在,那么判断目录路径是否存在,可否?可:

>>> os.path.exists("/foo/python/qiwsir")  

False

>>> os.path.exists("/home/qw/Documents")

True

判断相关的属性还有:

os.path.isabs(path):判断path是否为绝对路径
os.paht.isdir(path):判断path是否为存在的目录
组合路径

将两个或多个对象组合起来,是常见的事情,那么如何将多个路径组合呢?如下:

>>> os.path.join("/home/python","/BasicsPython","226.md")

'/BasicsPython/226.md'

特别提醒,这个属性的返回值中,将第一个绝对路径忽略。

>>> os.path.join("/","/home/qw","learnpython.md")

'/home/qw/learnpython.md'

Python 相关文章推荐
python判断端口是否打开的实现代码
Feb 10 Python
scrapy爬虫实例分享
Dec 28 Python
pycharm+django创建一个搜索网页实例代码
Jan 24 Python
python时间日期函数与利用pandas进行时间序列处理详解
Mar 13 Python
Python中偏函数用法示例
Jun 07 Python
python使用原始套接字发送二层包(链路层帧)的方法
Jul 22 Python
python框架flask表单实现详解
Nov 04 Python
Python函数式编程指南:对生成器全面讲解
Nov 19 Python
pytorch加载自定义网络权重的实现
Jan 07 Python
python 中的[:-1]和[::-1]的具体使用
Feb 13 Python
Python图像处理二值化方法实例汇总
Jul 24 Python
python 偷懒技巧——使用 keyboard 录制键盘事件
Sep 21 Python
跟老齐学Python之私有函数和专有方法
Oct 24 #Python
跟老齐学Python之模块的加载
Oct 24 #Python
python和shell实现的校验IP地址合法性脚本分享
Oct 23 #Python
探寻python多线程ctrl+c退出问题解决方案
Oct 23 #Python
纯Python开发的nosql数据库CodernityDB介绍和使用实例
Oct 23 #Python
Python中使用scapy模拟数据包实现arp攻击、dns放大攻击例子
Oct 23 #Python
使用Python开发windows GUI程序入门实例
Oct 23 #Python
You might like
php文件上传的例子及参数详解
2013/12/12 PHP
php面向对象与面向过程两种方法给图片添加文字水印
2015/08/26 PHP
解析javascript 数组以及json元素的添加删除
2013/06/26 Javascript
3种不同方式的焦点图轮播特效分享
2013/10/30 Javascript
jquery选择器大全 全面详解jquery选择器
2014/03/06 Javascript
javascript数组详解
2014/10/22 Javascript
AngularJS在IE下取数据总是缓存问题的解决方法
2016/08/05 Javascript
jQuery+ajax读取并解析XML文件的方法
2016/09/09 Javascript
Angular.JS去掉访问路径URL中的#号详解
2017/03/30 Javascript
详解nodejs微信jssdk后端接口
2017/05/25 NodeJs
解决webpack -p压缩打包react报语法错误的方法
2017/07/03 Javascript
Angular 如何使用第三方库的方法
2018/04/18 Javascript
js 数组详细操作方法及解析合集
2018/06/01 Javascript
微信小程序scroll-view点击项自动居中效果的实现
2020/03/25 Javascript
ES6箭头函数和扩展实例分析
2020/05/23 Javascript
[01:23]一分钟告诉你 DOTA2为什么叫信仰2
2014/06/20 DOTA
pygame学习笔记(3):运动速率、时间、事件、文字
2015/04/15 Python
在Django的form中使用CSS进行设计的方法
2015/07/18 Python
Python中用psycopg2模块操作PostgreSQL方法
2017/11/28 Python
高效使用Python字典的清单
2018/04/04 Python
Pandas 数据处理,数据清洗详解
2018/07/10 Python
pandas中apply和transform方法的性能比较及区别介绍
2018/10/30 Python
只需7行Python代码玩转微信自动聊天
2019/01/27 Python
使用OpenCV实现仿射变换—旋转功能
2019/08/29 Python
python多继承(钻石继承)问题和解决方法简单示例
2019/10/21 Python
python如何使用jt400.jar包代码实例
2019/12/20 Python
django从后台返回html代码的实例
2020/03/11 Python
Python如何测试stdout输出
2020/08/10 Python
python如何写个俄罗斯方块
2020/11/06 Python
Python创建自己的加密货币的示例
2021/03/01 Python
HTML5 Canvas的性能提高技巧经验分享
2013/07/02 HTML / CSS
教师求职自荐信
2014/03/09 职场文书
教学改革实施方案
2014/03/31 职场文书
英语辞职信范文
2015/02/28 职场文书
2015年度培训工作总结范文
2015/04/02 职场文书
禁毒主题班会教案
2015/08/14 职场文书