os.path模块用法:

1, os.path.basename()

>>> os.path.basename('/share/Public/cmiao')
'cmiao'

basename()函数并不会去判断这个路径是否存在,它只是简单的将最后一个/后面的作为文件名返回。至于是不是它不管
>>> os.path.basename('/share/Public/cmiao/')
''

由于最后一个/没有东西,他就认为这个目录路径,没有文件名。所以返回了空字符串

2, os.path.dirname()

和basename()一样,并不会去判断此路径是否存在。只是单纯的返回最后一个/前面的内容

>>> os.path.dirname('/share/Public/cmiao/')
'/share/Public/cmiao'

它认为这个是目录
>>> os.path.dirname('/share/Public/cmiao')
'/share/Public'

由于cmiao后面没有加反斜杠,所以认为cmiao是个文件名。

3,  os.path.join()

将目录和文件名合并。并不去检查是否存在,只是单纯的合并

>>> os.path.join('dfjds','sfd')
'dfjds/sfd'

两个都没有/, 默认将前一个作为目录名,后一个作为文件名。
>>> os.path.join('/dfjds','sfd')
'/dfjds/sfd'
>>> os.path.join('/dfjds/','sfd/')
'/dfjds/sfd/'

两个都有/ , 那就都是目录
>>> os.path.join('/dfjds/','sfd/','werw')
'/dfjds/sfd/werw'
>>> os.path.join('/dfjds/','sfd/','sfd/sdf.fa')
'/dfjds/sfd/sfd/sdf.fa'

就算目录有重复,他也不会去掉重复。。。

4, os.path.split()

将一个路径分开成文件名和目录名,并不会检查这个目录是否真的存在,最终以元组的形式返回

>>> os.path.split('sfdfa/gert')
('sfdfa', 'gert')

以最后一个/为分界线,/右边为文件名,左边为目录名, 返回的目录名最右边是没有/的
>>> os.path.split('sfdfa/gert/')
('sfdfa/gert', '')

最后一个/后面没有内容, 所以文件名为空字符''

>>> os.path.split('/sfdfa/gert/dfs.fa')
('/sfdfa/gert', 'dfs.fa')

其实split()返回的第一个元素就是os.path.dirname(), 第二个元素就是os.path.basename()

5,os.path.abspath()

返回你所给路径的绝度路径。

>>> os.path.abspath('sjfdl/sdfj.fa')
'/share/Public/cmiao/MyScripts/call_snp_pipeline/sjfdl/sdfj.fa'

这个很有意思, 如果你第一个目录前面没有/, 他就认为第一个目录是在当前目录下,就会补全当前目录的绝对路径。

>>> os.path.abspath('/sjfdl/sdfj.fa')
'/sjfdl/sdfj.fa'

如果第一个目录名前面有/ 就认为是从根目录开始的绝度路径
>>> os.path.abspath('./sjfdl/sdfj.fa')
'/share/Public/cmiao/MyScripts/call_snp_pipeline/sjfdl/sdfj.fa'

最前面有./ 和什么都没有是一样的
>>> os.path.abspath('./sjfdl/sdfj')
'/share/Public/cmiao/MyScripts/call_snp_pipeline/sjfdl/sdfj'
>>> os.path.abspath('./sjfdl/sdfj/')
'/share/Public/cmiao/MyScripts/call_snp_pipeline/sjfdl/sdfj'

最后一个有没有/是一样的
>>> os.path.abspath('../sjfdl/sdfj/')
'/share/Public/cmiao/MyScripts/sjfdl/sdfj'

..是上个目录,会返回上个目录的绝对路径。

也就是说,它自己算的那部分绝度路径是正确的,他不管你给的路径正确不正确

6,os.path.isabs()

判断指定的路径是否为绝对路径

>>> os.path.isabs('sdf/sfad.fa')
False

>>> os.path.isabs('./sdf/')
False
>>> os.path.isabs('/sdf/sfad.fa')
True
>>> os.path.isabs('/sdf/')
True
>>> os.path.isabs('sdf/')
False

第一个目录名前没有/, 目录中有. 或者.. 都会返回False

7, os.path.exists()

判断路径是否存在

>>> os.path.exists('./sdf/')
False

当前目录下没有sdf这个目录,所以返回False
>>> os.path.exists('./')
True

当前目录当然存在
>>> os.path.exists('share/')
False

share前面没有/, 认为是当前目录下,当前目录下没有share, 所以返回False
>>> os.path.exists('/share/')
True

根目录下有/share目录, 所以返回True

8, os.path.isfile()

判断路径是否存在, 并且是否是个文件

>>> os.path.isfile('/share/Public/cmiao/bwa-0.7.8.tar.bz2')
True

最后一个文件名确实在这个目录里, 返回True
>>> os.path.isfile('/share/Public/cmiao')
False

最后一个cmiao后虽然没有/,  但是isfile()会判断是文件还是目录。cmiao是目录,所以返回False。 如果用basename()会将cmiao返回。

9, os.path.isdir()

判断路径是否存在,并且是个目录。

by freemao

FAFU

free_mao@qq.com

python os.path 模块的更多相关文章

  1. 【308】Python os.path 模块常用方法

    参考:Python os.path 模块 参考:python3中,os.path模块下常用的用法总结 01   abspath 返回一个目录的绝对路径. 02   basename 返回一个目录的基名 ...

  2. python os.path模块--转载

    os.path.abspath(path) #返回绝对路径 os.path.basename(path) #返回文件名 os.path.commonprefix(list) #返回list(多个路径) ...

  3. [转载]python os.path模块

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.ht ...

  4. python:os.path模块常用方法

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.ht ...

  5. python os.path模块常用方法详解

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.ht ...

  6. python os.path模块常用方法详解(转)

    转自:https://www.cnblogs.com/wuxie1989/p/5623435.html os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方 ...

  7. python os.path模块常用方法详解 ZZ

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.ht ...

  8. [转]Python os.path模块

    os.path模块 原文链接:http://my.oschina.net/cuffica/blog/33494 basename('文件路径')    去掉目录路径,返回fname文件名 import ...

  9. python os.path模块用法详解

    abspath 返回一个目录的绝对路径 Return an absolute path. >>> os.path.abspath("/etc/sysconfig/selin ...

随机推荐

  1. 用js创建XMLHttpRequest对象池[转]

    //使用literal语法定义一个对象:XMLHttp var XMLHttp = { //定义第一个属性,该属性用于缓存XMLHttpRequest对象的数组 XMLHttpRequestPool: ...

  2. 重点关注之自定义序列化方式(Protobuf和Msgpack)

    除了默认的JSON和XML序列化器外,如果想使用其它格式的(比如二进制)序列化器,也是可以的.比如著名的Protobuf和Msgpack,它们都是二进制的序列化器,特点是速度快,体积小.使用方法如下. ...

  3. EF的Model First

    一,添加ADO.NET实体数据模型(即edmx) 1,添加edmx         新建一个类库项目,项目中添加新项,选择数据/ADO.NET实体数据模型,如下图.   点击添加,实体数据模型向导窗口 ...

  4. Android——关于Activity跳转的返回(无返回值和有返回值)——有返回值

    说明: 跳转页面,并将第一页的Edittext输入的数据通过按钮Button传到第二页用Edittext显示,点击第二页的 返回按钮Button返回第一页(改变第二页的Edittext的内容会传至第一 ...

  5. 二分搜索法(转载自vanezkw)

    二分查找算法java实现 今天看了一下JDK里面的二分法是实现,觉得有点小问题.二分法的实现有多种今天就给大家分享两种.一种是递归方式的,一种是非递归方式的.先来看看一些基础的东西. 1.算法概念. ...

  6. jsp作用域

    1.page: JSP页面内所有实例的默认作用域都是page,仅限于本页面使用 2.request: 同一次请求所涉及的服务器资源(可能是页面.Servlet等),例如,程序使用<jsp:for ...

  7. 怎么用navicat自动备份mysql数据库

    打开navicat客户端,连上mysql后,双击左边你想要备份的数据库.点击“计划”,再点击“新建批处理作业”.   双击上面的可用任务,它就会到下面的列表里去,代表你选择了这个任务.   点击保存, ...

  8. CodeForces 546B-Soldier and Badges

    题意: 给出一些数字,要求每个数字都不一样需要增加几 思路: 先排序,然后一个个增加,最后求总和差 代码如下: #include <iostream> #include <cstdi ...

  9. vi编辑器选项

    Vi编辑器有一些选项设置可以帮助人们更好的使用. 在vi中选项分为两种: 1.  开关选项,如果要打开这类选项就使用ex命令——:set 选项:如果要关闭这类选项就是用ex命令——:set  no选项 ...

  10. 在T-SQL中访问远程数据库(openrowset、opendatasource、openquery)

    1.  启用Ad Hoc Distributed Queries 在使用openrowset/opendatasource前要先启用Ad Hoc Distributed Queries服务,因为这个服 ...