环境
  虚拟机:VMware 10
  Linux版本:CentOS-6.5-x86_64
  客户端:Xshell4
  FTP:Xftp4
  python3.6

一、文件的打开与关闭

使用open函数,可以打开一个已经存在的文件,或者创建一个新文件,使用close()关闭文件

格式:
open(文件名,访问模式)
close()

示例:

  1. f=open('test.txt','w')
  2. f.close()

访问模式

说明

r

以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。

w

打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

a

打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

rb

以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。

wb

以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

ab

以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。也就是说,新的内容将会被写入到已有内容之后。如果该文件不存在,创建新文件进行写入。

r+

打开一个文件用于读写。文件指针将会放在文件的开头。

w+

打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

a+

打开一个文件用于读写。如果该文件已存在,文件指针将会放在文件的结尾。文件打开时会是追加模式。如果该文件不存在,创建新文件用于读写。

rb+

以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。

wb+

以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

ab+

以二进制格式打开一个文件用于追加。如果该文件已存在,文件指针将会放在文件的结尾。如果该文件不存在,创建新文件用于读写。

二、文件的读写
1、写数据(write)
注意:如果文件不存在那么创建,如果存在那么就先清空,然后写入数据

  1. f=open('test.txt','w')
  2. f.write('hello python,t am here!')
  3. f.close()

2、读数据(read)
使用read(num)可以从文件中读取数据,num表示要从文件中读取的数据的长度(单位是字节),如果没有传入num,那么就表示读取文件中所有的数据

  1. f=open('test.txt', 'r')
  2. content=f.read(10)
  3. print(content)
  4. print('-'*30)
  5. content=f.read()#从上次读完后的位置开始的
  6. print(content)
  7. f.close()
  8. 结果:
  9. hello pyth
  10. ------------------------------
  11. on,t am here!
  12. hello python,t am here!
  13. hello python,t am here!
  14. hello python,t am here!
  15. hello python,t am here!

注意:如果open是打开同一个文件,那么可以不用设置打开的模式,即只写 open('test.txt'),如果使用读了多次,那么后面读取的数据是从上次读完后的位置开始的

3、读数据(readlines)
readlines可以按照行的方式把整个文件中的内容进行一次性读取,并且返回的是一个列表,其中每一行的数据为一个元素

  1. f=open('test.txt','r')
  2. contents=f.readlines()
  3. for line in contents:
  4. print(line)
  5. f.close()

4、读数据(readline)
一行一行的读取

  1. f=open('test.txt','r')
  2. content=f.readline()
  3. print(content)
  4. print(content)
  5. print(content)
  6. f.close()

三、文件的定位读写
1、获取当前读写的位置:在读写文件的过程中,如果想知道当前的位置,可以使用tell()来获取

  1. f=open('test.txt','r')
  2. print(f.read(5))
  3. print(f.tell())#打印文件操作位置:5
  4. print(f.read(5))
  5. print(f.tell())#打印文件操作位置:10
  6. f.close()

2、定位到某个位置
如果在读写文件的过程中,需要从另外一个位置进行操作的话,可以使用seek()
seek(offset, from)
有2个参数
offset:偏移量
from:方向
  0:表示文件开头
  1:表示当前位置
  2:表示文件末尾

#把位置设置为:从文件开头,偏移5个字节

  1. f=open('test.txt','r')
  2. print(f.read(30))
  3. print(f.tell())#操作位置:31
  4. f.seek(5,0)
  5. print(f.tell())#
  6. f.close()

#把位置设置为:离文件末尾,3字节处 距离右侧要用负数偏移量

  1. f=open('test.txt','rb')#如果使用r模式 会报错:io.UnsupportedOperation: can't do nonzero end-relative seeks
  2. print(f.tell())#
  3. f.seek(-3,2)
  4. print(f.tell())#
  5. f.close()

四、文件的相关操作
对文件进行重命名、删除等操作,需要引入与平台无关的os模块,
import os
1、os.name——判断现在正在实用的平台,Windows 返回 ‘nt'; Linux 返回’posix'
os.rename(需要修改的文件名, 新的文件名) 也可以做剪切。
2、os.getcwd()——得到当前工作的目录(get current work dir)。
3、os.listdir()——指定所有目录下所有的文件和目录名。以列表的形式全部列举出来,其中没有区分目录和文件。
4、os.remove()——删除指定文件
5、os.rmdir()——删除指定目录 :该目录要为空
6、os.mkdir()——创建一层目录,要想递归建立可用:os.makedirs(x/y/z)
7、os.path.isfile()——判断指定对象是否为文件。是返回True,否则False 注意:路径要使用转义字符\\
8、os.path.isdir()——判断指定对象是否为目录。是True,否则False。例:
9、os.path.exists()——检验指定的对象是否存在。是True,否则False.例:
10、os.path.split()——返回路径的目录和文件名,返回是一个元组。此处只是把前后两部分分开而已。就是找最后一个'/'
11、os.system()——执行shell命令。例:
12、os.environ--返回系统环境变量
13、os.chdir()——改变目录到指定目录
14、os.path.getsize()——获得文件的大小,如果为目录,返回0
15. os.path.abspath()——获得绝对路径。
16. os.path.join(path, name)——连接目录和文件名。
17.os.path.basename(path)——返回文件名
18. os.path.dirname(path)——返回文件所在目录

示例:

  1. import os
  2. print(os.name)#nt
  3. os.rename('test.txt','ab.txt')
  4. print(os.getcwd())#E:\workspace\py_workspace\Python_demo\src\com\wjy
  5. dirs=os.listdir('E:\workspace\py_workspace\Python_demo\src\com')
  6. for dir in dirs:
  7. print(dir)
  8. os.remove('ab.txt')
  9. os.rmdir('E:\\12')#删除路径使用转义\\,如果目录不为空 会报错:OSError: [WinError 145] 目录不是空的。
  10. os.mkdir('E:\\x')
  11. os.makedirs('E:\\x\\y\\z')
  12. print(os.path.isfile('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy\\filetest.py'))
  13. print(os.path.isdir('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy'))
  14. print(os.path.exists('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy'))
  15. print(os.path.split('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy\\filetest.py'))
  16. os.system('echo 123') #
  17. print(os.environ)#返回一元组,元组内是一个字典:environ({...})
  18. os.chdir('E:\\workspace\\py_workspace\\Python_demo\\src')
  19. print(os.path.getsize('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy\\filetest.py'))
  20. print(os.path.abspath('filetest.py'))
  21. print(os.path.join('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy','filetest.py'))
  22. print(os.path.basename('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy\\filetest.py'))
  23. print(os.path.dirname('E:\\workspace\\py_workspace\\Python_demo\\src\\com\\wjy\\filetest.py'))

参考:
Python学习笔记

【Python学习之六】文件操作的更多相关文章

  1. python学习笔记:文件操作和集合(转)

    转自:http://www.nnzhp.cn/article/16/ 这篇博客来说一下python对文件的操作. 对文件的操作分三步: 1.打开文件获取文件的句柄,句柄就理解为这个文件 2.通过文件句 ...

  2. python学习总结---文件操作

    # 文件操作 ### 目录管理(os) - 示例 ```python # 执行系统命令 # 清屏 # os.system('cls') # 调出计算器 # os.system('calc') # 查看 ...

  3. python学习日记(文件操作)

    文件操作概述 计算机系统分为:操作系统,计算机硬件,应用程序. 我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应用程序 ...

  4. 03 python学习笔记-文件操作(三)

    本文内容主要包括以下方面: 1. 文件操作基本认识2. 只读(r, rb)3. 只写(w, wb)4. 追加(a, ab)5. r+读写6. w+写读7. a+写读(追加写读)8. 文件的修改 一.文 ...

  5. python学习day8 文件操作(深度学习)

    文件操作 (day7内容扩展) 1 文件基本操作 obj = open('路径',mode='模式',encoding='编码')obj.write()obj.read()obj.close() 2 ...

  6. python 学习分享-文件操作篇

    文件操作 f_open=open('*.txt','r')#以只读的方式(r)打开*.txt文件(需要与py文件在同一目录下,如果不同目录,需写全路径) f_open.close()#关闭文件 打开文 ...

  7. Python学习笔记——文件操作

    python中,一切皆对象.   一.文件操作流程 (1)打开文件,得到一个文件句柄(对象),赋给一个对象: (2)通过文件句柄对文件进行操作: (3)关闭文件. 文件对象f通过open()函数来创建 ...

  8. Python学习之==>文件操作

    1.打开文件的模式 r,只读模式(默认)[不可写:文件不存在,会报错] w,只写模式[不可读:不存在则创建:存在则删除内容] a,追加模式[不可读:不存在则创建:存在则追加内容] r+,读写模式[可读 ...

  9. Python学习之文件操作

    Python 文件打开方式 文件打开方法:open(name[,mode[buf]]) name:文件路径mode:打开方式buf:缓冲buffering大小 f = open('test.txt', ...

  10. Python学习 :文件操作

    文件基本操作流程: 一. 创建文件对象 二. 调用文件方法进行操作 三. 关闭文件(注意:只有在关闭文件后,才会写入数据) fh = open('李白诗句','w',encoding='utf-8') ...

随机推荐

  1. 编程小白入门分享二:IntelliJ IDEA的入门操作小知识

    idea简介 IDEA 全称 IntelliJ IDEA,是java编程语言开发的集成环境.IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助手.代码自动提示.重构.J2EE支 ...

  2. myeclipse常用快捷(持续更新)

    最近开始转用myeclipse,总结一下快捷方式:(我喜欢用的) [Ctrl+O]    显示类中方法和属性的大纲,能快速定位类的方法和属性,在查找Bug时非常有用. [Ctrl+M]    窗口最大 ...

  3. jQuery 查找和过滤

    通常情况下选择器可以直接定位到我们想要的元素,但是,当我们拿到一个jQuery对象后,还可以以这个对象为基准,进行查找和过滤. 最常见的查找是在某个节点的所有子节点中查找,使用find()方法,它本身 ...

  4. Dubbo源码分析:Serialization

    背景 顺序化逻缉处理! 类图 获取Serialization对象时序图 序列化

  5. Python2.7 报错:UnicodeEncodeError: 'ascii' codec can't encode characters in position 3-4: ordinal not in range(128)

    一. 错误原因(网上找的是这样说的,具体的我也不是很了解2.7版本的编码问题): 1.python默认使用ASCII处理字符流. 2.Unicode编码与ASCII编码的不兼容,Python脚本文件是 ...

  6. linux 出错 “INFO: task java: xxx blocked for more than 120 seconds.” 的3种解决方案

    1 问题描述 最近搭建的一个linux最小系统在运行到241秒时在控制台自动打印如下图信息,并且以后每隔120秒打印一次. 仔细阅读打印信息发现关键信息是“hung_task_timeout_secs ...

  7. BZOJ 4919: [Lydsy1706月赛]大根堆 set启发式合并

    这个和 bzoj 5469 几乎是同一道题,但是这里给出另一种做法. 你发现你要求的是一个树上 LIS,而序列上的 LIS 有一个特别神奇的 $O(n\log n) $ 做法. 就是维护一个单调递增的 ...

  8. hibernate的API

    程序源码: import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.Transa ...

  9. linux date获取时间戳

    linux 时间戳格式 年月日 时分秒: `date ‘+%Y%m%d%H%M%S’`date +%Y%m%d%H%M%S // 年月日 时分秒date +%s // 从 1970年1月1日零点开始到 ...

  10. 阿里云部署自己的web服务器

    阿里云部署自己的web服务器 [外链图片转存失败(img-GIKNTPPx-1564287221547)(https://upload-images.jianshu.io/upload_images/ ...