Python的os包与os.path模块的用法详情

目录
  • 一、os常用方法
    • 1.获取当前路径os.getcwd()
    • 2.获取指定路径下有哪些文件和目录,os.listdir(path)返回一个list
    • 3.创建目录(一级)os.mkdir(paht)
    • 4.删除文件os.remove(path)
    • 5.递归删除空目录os.removedirs(path)
    • 6.删除空目录os.rmdir(path)
    • 7.创建多级目录os.makedirs(path)
  • 二、os.path常用方法
    • 1.路径拼接os.path.join(path1,path2…)
    • 2.路径分离os.path.split(path)返回tuple
    • 3.判断是否是目录os.path.isdir(path)
    • 4.判断是否是文件os.path.isfile(paht)
    • 5.判断路径是否存在os.path.exists(path)
    • 6.判断路径是不是绝对路径os.path.isabs(path)

一、os常用方法

1.获取当前路径 os.getcwd()

# coding:utf-8
import os
if __name__ == '__main__':
    print(os.getcwd())  # G:\workSpace\py_d

2.获取指定路径下有哪些文件和目录,os.listdir(path)返回一个list

# coding:utf-8

import os

if __name__ == '__main__':
    print(os.listdir(os.getcwd()))  # ['.idea', 'main.py', 'os_module.py', 'sk']

3.创建目录(一级) os.mkdir(paht)

os.mkdir(path) 创建目录:

 以下两种情况会报错:

  • 2.要创建目录的上级目录不存在(a不存在,则不能创建b目录)
  • 3.要创建的目录已存在(b存在,则不能创建b目录)
# coding:utf-8

import os

if __name__ == '__main__':

    os.mkdir('sk/a/b')  # 在当前sk/a 目录中创建b目录
    # os.mkdir(os.path.join(os.getcwd(), 'sk', 'a', 'b')) 和上面的一样,只不过换成了绝对路径

4.删除文件 os.remove(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.remove(path)
    要求path是文件且存在
    """
    os.remove("sk/a/b/503.py")
    # os.remove(os.path.join(os.getcwd(), 'sk', 'a', 'b', '503.py')) 和上面的一样,只不过路径换成绝对路径了

5.递归删除空目录 os.removedirs(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.removedirs(path)
    如果最底层目录不是空目录直接报错(s2不是空目录则报错)
    从最第底层目录开始删,一直删到最上层目录(先删s2,再删s1),当要删除的目录不是空目录时停止(s1不是空目录则停止)
    """
    os.removedirs('s1/s2')
    # os.removedirs(os.path.join(os.getcwd(), 's1', 's2')) 和上面的一样,只不过使用了绝对路径

6.删除空目录 os.rmdir(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
      os.rmdir(path)
      path不存在且不是空目录则报错
    """
    os.rmdir('s1/s2')

7.创建多级目录 os.makedirs(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.makedirs(path,exists_ok=False) 创建多级目录
    如果path目录已存在则报错,可以设置exist_ok 参数来抑制错误,exist_ok不等于False就不会抛出异常
    """
    os.makedirs("s1/s3")
    os.makedirs("s1/s3", exist_ok=True)

二、os.path 常用方法

1.路径拼接 os.path.join(path1,path2…)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.join(path1,path2......)
    将多个路径拼接形成新的路径
    """
    print(os.path.join(os.getcwd(), 's1', 's2'))  # G:\workSpace\py_d\s1\s2

2.路径分离 os.path.split(path) 返回tuple

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.split(path) 分割路径,返回一个tuple,由两个元素构成
    第2个元素是path中最后一层的目录或者文件
    第1个元素是path中除去第二个元素后剩余的路径,可以为空字符串
    """
    path = os.path.join(os.getcwd(), 's1', 's2')
    print(path)  # G:\workSpace\py_d\s1\s2.my
    print(os.path.split(path))  # ('G:\\workSpace\\py_d\\s1', 's2.my')
    print(os.path.split('dir1'))  # ('', 'dir1')

3.判断是否是目录 os.path.isdir(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.is_dir(path) 判断路径是不是目录,当路径不存在也返回False
    """
    print(os.path.isdir(os.getcwd()))  # True
    print(os.path.isdir(os.path.join(os.getcwd(), 'main.py')))  # False 这是文件
    print(os.path.isdir('http://xxx.com'))  # 不存在也返回False

4.判断是否是文件 os.path.isfile(paht)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.is_file(path) 判断路径是不是文件,当路径不存在也返回False
    """

    print(os.path.isfile(os.getcwd()))  # False 这是目录
    print(os.path.isfile(os.path.join(os.getcwd(), 'main.py')))  # True 是文件
    print(os.path.isfile(os.path.join(os.getcwd(), 'abc')))  # False 不存在也返回False

5.判断路径是否存在 os.path.exists(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.exists(path) 判断路径是不是文件,当路径不存在也返回False
    """

    print(os.path.exists(os.path.join(os.getcwd(), 'main.py')))  # True main.py存在
    print(os.path.exists(os.path.join(os.getcwd(), 'abc.py')))  # False abc.py 不存在

6.判断路径是不是绝对路径 os.path.isabs(path)

# coding:utf-8

import os

if __name__ == '__main__':

    """
    os.path.abs(path) 判断路径是不是绝对路径,与存不存在无关
    """
    print(os.getcwd())  # G:\workSpace\py_d
    print(os.path.isabs(os.path.join(os.getcwd(), 'main.py')))  # True main.py存在
    print(os.path.isabs(os.path.join(os.getcwd(), 'abc.py')))   # True abc.py不存在
    print(os.path.isabs('a/b/c'))  # False

到此这篇关于Python的os包与os.path模块详情的文章就介绍到这了,更多相关Python的os包和os.path模块内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python中的os.path路径模块中的操作方法总结

    解析路径 路径解析依赖与os中定义的一些变量: os.sep-路径各部分之间的分隔符. os.extsep-文件名与文件扩展名之间的分隔符. os.pardir-路径中表示目录树上一级的部分. os.curdir-路径中当前目录的部分. split()函数将路径分解为两个单独的部分,并返回包含这些结果的tuple.第二个元素是路径的最后部分,地一个元素是其他部分. import os.path for path in [ '/one/two/three', '/one/two/three/',

  • Python对文件和目录进行操作的方法(file对象/os/os.path/shutil 模块)

    使用Python过程中,经常需要对文件和目录进行操作.所有file类/os/os.path/shutil模块时每个Python程序员必须学习的. 下面通过两段code来对其进行学习. 1. 学习 file对象 2. 学习os/os.path/shutil模块 1.file对象学习: 项目中需要从文件中读取配置参数,python可以从Json,xml等文件中读取数据,然后转换成Python的内容数据结构. 下面以Json文件为例,实现从Json文件中获取配置参数. code运行环境:python2

  • python3中os.path模块下常用的用法总结【推荐】

    abspath 返回一个目录的绝对路径 Return an absolute path. >>> os.path.abspath("/etc/sysconfig/selinux") '/etc/sysconfig/selinux' >>> os.getcwd() '/root' >>> os.path.abspath("python_modu") '/root/python_modu' basename 返回一个

  • Python常用模块os.path之文件及路径操作方法

    以下是 os.path 模块的几种常用方法: 方法 说明 os.path.abspath(path) 返回绝对路径 os.path.basename(path) 返回文件名 os.path.commonprefix(list) 返回list(多个路径)中,所有path共有的最长的路径 os.path.dirname(path) 返回文件路径 os.path.exists(path) 如果路径 path 存在,返回 True:如果路径 path 不存在,返回 False. os.path.lexi

  • 详谈Python3 操作系统与路径 模块(os / os.path / pathlib)

    以下代码以Python3.6.1 / windows10为例 Less is more! #!/usr/bin/env python # coding=utf-8 __author__ = 'Luzhuo' __date__ = '2017/5/7' import os def os_demo(): # 执行命令 dirs = os.popen("dir").read() print(dirs) # 打印目录树 dirs_info = os.scandir() for info in

  • python 中os模块os.path.exists()的用法说明

    os即operating system(操作系统),Python 的 os 模块封装了常见的文件和目录操作. os.path模块主要用于文件的属性获取,exists是"存在"的意思,所以顾名思义,os.path.exists()就是判断括号里的文件是否存在的意思,括号内的可以是文件路径. 举个栗子: user.py为存在于当前目录的一个文件 输入代码: import os path = os.path.exists('user.py') print(path) 输出结果: True P

  • python os.path模块常用方法实例详解

    os.path模块主要用于文件的属性获取,在编程中经常用到,以下是该模块的几种常用方法.更多的方法可以去查看官方文档:http://docs.python.org/library/os.path.html 1.os.path.abspath(path) 返回path规范化的绝对路径. >>> os.path.abspath('test.csv') 'C:\\Python25\\test.csv' >>> os.path.abspath('c:\\test.csv') '

  • python中os包的用法

    1 创建目录以及判断是否存在,如果不存在则创建 import os # 创建的目录 path = "yyy" if not os.path.exists(path): os.makedirs(path) os.path.exists('d:/assist/getTeacherList.py') #True or False 2 输出文件夹中的子文件夹以及文件 import os filePath = 'E:\BaiduNetdiskDownload\data\人工锄地' for fil

  • Python的os包与os.path模块的用法详情

    目录 一.os常用方法 1.获取当前路径os.getcwd() 2.获取指定路径下有哪些文件和目录,os.listdir(path)返回一个list 3.创建目录(一级)os.mkdir(paht) 4.删除文件os.remove(path) 5.递归删除空目录os.removedirs(path) 6.删除空目录os.rmdir(path) 7.创建多级目录os.makedirs(path) 二.os.path常用方法 1.路径拼接os.path.join(path1,path2…) 2.路径

  • Python学习之os包使用教程详解

    目录 os 模块 文件与目录函数介绍 path 模块 ​path 模块常用方法 今天我们来学习一下 python 的内置包 —> OS 包.OS 包拥有着普遍的操作系统功能,拥有着各种各样的函数来操作系统的驱动功能.其中最常用的就是对 路径 与 文件的操作,比如检查某个路径下是否存在某个文件,某个路径是否存在等.也可以创建.删除文件等,接下来我们就详细的看一看 OS 中关于文件的操作功能与用法. os 模块 文件与目录函数介绍 函数名 参数 介绍 举例  返回值 getcwd 没有参数 返回当前

  • Python os和os.path模块详情

    1.目的:在Python中实现只读取扩展名为xlsx的文件 解决方法: 使用os模块. 解决思路: 1.确定目录 2.循环遍历每一个文件 3.筛选符合条件的文件,读取数据 具体代码如下: import os # 1.首先定义路径 filepath = 'E:/old/工作/数据库表' # 2.循环遍历路径下的每一个文件 for filename in os.listdir(filepath):     # 3.列出文件中以.xlsx结尾的文件     if filename.endswith((

  • python os.path模块使用方法介绍

    os.path模块是os模块根据系统类型从另一个模块导入的,并非由os模块实现 1.os.path.abspath(相对路径)-----返回对应路径的绝对路径 os.path.abspath(".") import os.path print(os.path.abspath(".")) E:\python练习 上一层路径“..” import os.path print(os.path.abspath("..")) E:\ 2.os.path.a

  • python中内置库os与sys模块的详细介绍

    目录 os包 sys模块 os包 想要使用os包一样要先导入:import os os包下可以直接调用的函数 下面介绍一下os包中可以直接调用的函数: 例子: 例子: 例子: 注意:os.path.exists()参数可以传绝对路径,也可以传相对路径: 已知一个文件的路径,可以用spilt切割出这个文件名: sys模块 sys模块常用于操作当前的操作系统/环境 sys中常用的函数: 例子: 关于argv我们知道,他可以从程序外部获取参数,我们让他从终端传入参数给程序. 举一个详细的例子介绍: 可

  • python 中文件输入输出及os模块对文件系统的操作方法

    整理了一下python 中文件的输入输出及主要介绍一些os模块中对文件系统的操作. 文件输入输出 1.内建函数open(file_name,文件打开模式,通用换行符支持),打开文件返回文件对象. 2.对打开文件进行读取时,readline()与readlines()的区别在于是否一次性的读取所有的内容,并将每行的信息作为列表中的一个子项. 例如:文件test.txt中 1,3,4   2,35,6 分别用readline与readlines对其进行读取 r=file_object.readlin

随机推荐