Python关于OS文件目录处理的实例分享
作者:Z_Queen 发布时间:2022-12-29 08:52:07
Python----OS 文件目录处理
import os
import time
# 获取当前文件的绝对路径
dir_1 = os.path.abspath(__file__) # D:\workspace\web-test\Study\Day_5-16\tset3.py
# 获取当前文件所在目录的上级路径
dir_2 = os.getcwd() # D:\workspace\web-test\Study\Day_5-16
dir_3_1 = os.path.dirname(dir_1) # D:\workspace\web-test\Study\Day_5-16
dir_3_2 = os.path.dirname(dir_3_1) # D:\workspace\web-test\Study
# 获取当前文件所在目录的上级路径
dir_4 = os.path.abspath(os.path.join(os.getcwd(),"./")) # D:\workspace\web-test\Study\Day_5-16
dir_5 = os.path.abspath(os.path.join(os.getcwd(),"../")) # D:\workspace\web-test\Study
dir_6 = os.path.abspath(os.path.join(os.getcwd(),"../../")) # D:\workspace\web-test
# 获取当前日期
new_time_day = time.strftime('%Y-%m-%d') # 2021-05-21
# 拼接目录
dir_image_day_pingjie = os.path.join(dir_4,new_time_day) # D:\workspace\web-test\Study\Day_5-16\2021-05-21
#判断目录是否存在,不存在就创建
if not os.path.exists(dir_image_day_pingjie):
#创建文件
os.mkdir(dir_image_day_pingjie)
import os
# os.mkdir("n1") # 创建目录
# 创建文件
# with open('1.txt',mode='w') as file:
# file.write('11111')
# os.mknod("n1.txt") # 创建文件,windows上面不支持,linux中支持
url = r"D:\workspace\test36-demo\study\Day_4_13\n2"
print('n2目录下的内容',os.listdir(url)) #列出目录下的所有目录和文件
# os.rename('1.txt','2.txt') # 文件重命名
print(os.getcwd()) # 获取当前目录(绝对路径 )
# os.rmdir('n1') # 删除一个空目录
# os.remove('1.txt') # 删除一个文件
print("文件/目录是否存在:",os.path.exists('1.txt')) # 判断文件/目录是否存在,结果 True/False
print('对象是否为目录:',os.path.isdir('2.txt')) # 判断目录是否存在,是True/否False
print('对象是否为文件:',os.path.isfile('2.txt')) # 判断文件是否存在,是True/否False
print('文件/目录的绝对路径:',os.path.abspath('n1/n1.txt')) # 获取文件/目录的绝对路径
print('获取文件的大小:',os.path.getsize('n1/n1.txt')) # 获取文件的大小(单位:b 字节)
url_name = r"D:\workspace\test36-demo\study\Day_4_13\n1\n1.txt"
name = os.path.basename(url) # 获取文件名/文件夹的名称
dir = os.path.dirname(url) # 获取文件/文件夹的路径
print('dir---->',dir,'\t\t\t','name---->',name)
print('分离文件名与扩展名:',os.path.splitext('aa.py')) # 只会进行分离,不会判断文件是否真实存在
print('分离路径和文件:',os.path.split('D:\w1\w2\w3')) # 只会进行分离,不会判断目录及文件是否真实存在
print('\n\n--------------------------------作业-----------------------------')
# 练习一:判断文件夹是否存在,不存在就创建文件夹,存在就进去,创建一个文件
if os.path.exists("n1") == False:
os.mkdir('n1')
os.chdir('n1') # 进入目录
with open('n1.txt',mode='w') as file:
file.write('我的新的')
# 练习二:获取n2文件夹下面的所有内容,删除所有的文件夹
url2 = r"D:\workspace\test36-demo\study\Day_4_13\n2"
data = os.listdir(url2) #列出目录下的所有目录和文件
for i in data:
if os.path.isdir(os.path.join(url2,i)) == True: # 判断是否是目录
os.rmdir(os.path.join(url2,i)) # 是目录则删除
# 练习三:自己实现一个os.path.split 分离目录与文件夹
url_name = r"D:\workspace\test36-demo\study\Day_4_13\n1"
name = os.path.basename(url) # 获取文件名/文件夹的名称
dir = os.path.dirname(url) # 获取文件/文件夹的路径
print('目录---->',dir,'\t\t\t','文件夹---->',name)
知识点扩展:
Python OS 模块 文件目录操作
os模块中包含了一系列文件操作的函数,这里介绍的是一些在Linux平台上应用的文件操作函数。由于Linux是C写的,低层的libc库和系统调用的接口都是C API,而Python的os模块中包括了对这写接口的Python实现,通过Python的os模块,可以调用系统的功能,进行系统编程。
下面介绍一下os模块中提供的一些文件操作(仅限Unix平台):
返回文件对象的操作
os.fdopen(fd, [mode, [bufsize]])
通过文件描述符 fd 创建一个文件对象,并返回这个文件对象
fd参数是一个打开的文件的描述符,在Unix下,描述符是一个小整数。
mode参数是可选的,和buffersize参数和Python内建的open函数一样,mode参数可以指定‘r,w,a,r+,w+,a+,b'等,表示文件的是只读的还是可以读写的,以及打开文件是以二进制还是文本形式打开。这些参数和C语言中的<stdio.h>中fopen函数中指定的mode参数类似。
bufsize参数是可选的,指定返回的文件对象是否带缓冲:buffersize=0,表示没有带缓冲;bufsize=1,表示该文件对象是行缓冲的;bufsize=正数,表示使用一个指定大小的缓冲冲,单位为byte,但是这个大小不是精确的;bufsize=负数,表示使用一个系统默认大小的缓冲,对于tty字符设备一般是行缓冲,而对于其他文件则一般是全缓冲。如果这个参数没有制定,则使用系统默认的缓冲设定。
os.popen(command, [mode, [bufsize]])
开启一个子进程执行一个command指定的命令,在父进程和子进程之间建立一个管道pipe,用于在父子进程间通信。返回一个文件对象,可以对这个文件对象进行读或写,取决于参数mode,如果mode指定了只读,那么只能对文件对象进行读,如果mode参数指定了只写,那么只能对文件对象进行写操作。
command参数指定需要在子进程中执行的命令.
mode参数和bufsize参数和上述的os.fdopen一样。
os.popen函数还有一些其他的变种,可以按需要使用:
os.popen2(command, [mode, [bufsize]])
在子进程中执行命令command,返回一个二元组(child_stdin, child_stdout)
os.popen3(command, [mode, [bufsize]])
在子进程中执行命令command,返回一个三元组(child_stdin, child_stdout, child_stderr)
os.popen4(command, [mode, [bufsize]])
在子进程中执行命令command,返回一个二元组(child_stdin, child_stdout_and_stderr)
os.tmpfile()
返回一个以”w+b“模式打开的文件对象,该文件对象对应的文件无法通过目录访问,这是一个临时文件,当文件对象被关闭的时候,该临时文件也就被删除。
来源:https://www.cnblogs.com/Z-Queen/p/14725533.html
猜你喜欢
- 作者:做梦的人(小姐姐)出处:https://www.cnblogs.com/chongyou/1.所有元素都在PageElement下的.
- 环境:Python+keras,后端为Tensorflow训练集:MNIST对于如何训练一个识别手写数字的神经网络,网上资源十分丰富,并且能
- 密钥密码'''如密钥短语密码为: university -> universty明文: abcdefghijk
- css usage是一个基于firebug的firefox扩展,可以用来查看页面中的CSS的使用情况,可以清楚的查看css文件中所有的规则在
- 在正文前,先简短介绍自己。我任职于广州的某个网站服务公司的系统开发员,主要任务是以.Net编写各种web系统,例如CMS.EIP。大家都知道
- 本文分别介绍了安装python2和python3的详细方法,分享给大家。一、Windows系统很多童鞋问之前的教程怎么没有介绍安装pytho
- 使用python将图片改为灰度图或黑白图有三种方式,分别是是使用cv2库和PIL库来实现,详细过程如下所示。1. 使用cv2库将图片改为灰度
- 本文实例讲述了Ubuntu下使用Python实现游戏制作中的切分图片功能。分享给大家供大家参考,具体如下:why拿到一个人物行走的素材,要用
- 1. os.listdir()概述os.listdir() 方法用于返回指定的文件夹包含的文件或文件夹的名字的列表。例如:dir ='
- 使用TensorFlow的一个优势是,它可以维护操作状态和基于反向传播自动地更新模型变量。 TensorFlow通过计算图来更新变量和最小化
- 背景:我在爬虫处理某个文本时,用到了re.findall(),而不是re.compile。远在新加坡的同事提出了质疑,认为以我的水平,不应该
- 如下所示:dic = dict()dic['a'] = 1dic['b'] = 2dic['c
- 1. 欧几里德算法欧几里德算法又称辗转相除法, 用于计算两个整数a, b的最大公约数。其计算原理依赖于下面的定理:定理: gcd(a, b)
- 一、保存:graph_util.convert_variables_to_constants 可以把当前session的计算图串行化成一个字
- 哈喽,今天给大家分享一篇Django+Celery实现动态配置定时任务,因为最近也是无意间看到一位大佬关于这块的文章,然后自己觉得不错,也想
- zy3287 问:<script src="js.js?id=999" type="text/javas
- 简单的LSTM问题,能够预测一句话的下一个字词是什么固定长度的句子,一个句子有3个词。使用one-hot编码各种引用import keras
- 今天带你们去研究一个有趣的东西,文字识别OCR。不知道你们有没有想要识别图片,然后读出文字的功能。例如验证码,如果需要自动填写的话就需要这功
- 例子:(简 > 繁)面包 > 麵包 (zh-tw)寮国 > 老撾 (zh-hk)中国人寿 > 中國人壽 (zh-hk
- 1、说明拼接文件路径,可以有多个参数。2、语法os.path.join(path1,path2,*)path1 初始路径。path2 需要拼