当前位置: 首页 > news >正文

【289】◀▶ Python I/O 读写文本文件

参考:Python 文件 I/O

参考:Python OS 文件/目录方法


  目录:

01 open 函数用于打开一个文件,创建一个 file 对象,相关的方法才可以调用它进行读写。
02 File 对象file 对象使用 open 函数来创建。
03 rename 方法用于命名文件或目录。
04 remove 方法用于删除指定路径的文件。
05 mkdir 方法用于以数字权限模式创建目录。
  makedirs 方法用于多级创建目录。
06 chdir 方法用于改变当前工作目录到指定的路径。
07 getcwd 方法用于返回当前工作目录。
08 rmdir 方法用于删除指定路径的目录。
09 

listdir 方法

用于返回指定的文件夹包含的文件或文件夹的名字的列表。
10 input 方法接受一个标准输入数据。
11 raw_input 方法将所有输入作为字符串看待,返回字符串类型。
--------   ------------------- -----------------------------------------------------------------------------------------------------

  文本文件读写举例:

# 实现功能:从数据中每隔4行选取一个
def a():
	fo = open("D:\\tmp\\a.txt", "r+")
    	fo_w = open("D:\\tmp\\a1.txt", "w+")
	lines_new = fo.readlines()
	i = 0
	for l in lines_new:
		if i%4==0:
			fo_w.writelines(l[0:-1])
		i+=1
	fo.close()
	fo_w.close()

# 实现功能:为每一个行文件添加后缀
def c():
	fo = open("D:\\tmp\\a.txt", "r+")
	fo_w = open("D:\\tmp\\a2.txt", "w+")
	lines_new = fo.readlines()
	for l in lines_new:
		fo_w.writelines(l+".zip\n")
	fo.close()
	fo_w.close()

 


 

  详细说明:

序号类名称 

功能说明

 语法 & 举例
01open 函数 

====<<<< Description >>>>====

用于打开一个文件,创建一个  file  对象,相关的方法才可以调用它进行读写。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

open (name[, mode[, buffering]])
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  name:一个包含了你要访问的文件名称的字符串值。
◈  mode:mode 决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。
◈  buffering:如果 buffering 的值被设为 0,就不会有寄存。如果 buffering 的值取 1,访问文件时会寄存行。如果将 buffering 的值设为大于 1 的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。
----------------------------------------------------------------------------------

====<<<< mode >>>>====

◈  r:以只读方式打开文件。文件的指针将会放在文件的开头。这是默认模式。文件不存在报错
◈  r+:打开一个文件用于读写。文件指针将会放在文件的开头。文件不存在报错
◈  w:打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件
◈  w+:打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件

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

----------------------------------------------------------------------------------

====<<<< References >>>>====

参考:python文件打开方式详解——a、a+、r+、w+区别
参考:python 文件读写模式r,r+,w,w+,a,a+的区别(附代码示例)

 
# 获取栅格数据
arcpy.env.workspace=r"D:\01-Working\2017\20171204-IDL_Average\temp\TSM"
rs = arcpy.ListRasters()

# 遍历栅格数据获取统计信息
# 首先需要建立栅格文件
# 将数据结果保留两位小数
# 输出到txt文档中

fo = open("D:\\01-Working\\2017\\2017_Average\\temp\\tsm_stats.txt", "w+")
for r in rs:
    ro = arcpy.Raster(r)
    fo.writelines(ro.name + "\n")
    fo.writelines("MAX: " + str(round(ro.maximum, 2)) + "\n")
    fo.writelines("MIN: " + str(round(ro.minimum, 2)) + "\n")
    fo.writelines("MEAN: " + str(round(ro.mean, 2)) + "\n\n")
    
fo.close()

读入文件示例:

>>> import os
>>> fo = open("D:\\03-Study\\Python\\test\\test.txt", "r+")
>>># 读取全部为一个字符串(read)
>>> lines = fo.read()
>>> lines
'Line 1: aaaaaa\nLine 2: bbbbbb\nLine 3: cccccc\nLine
>>> print lines
Line 1: aaaaaa
Line 2: bbbbbb
Line 3: cccccc
>>> fo.tell()
110L
>>># 指针返回初始位置
>>> fo.seek(0)
>>> fo.tell()
0L
>>># 读取数据的一行(readline)
>>> lines_new = fo.readline()
>>> lines_new
'Line 1: aaaaaa\n'
>>># 读取剩下的数据为一个列表(readlines)
>>> lines_new2 = fo.readlines()
>>> lines_new2
['Line 2: bbbbbb\n', 'Line 3: cccccc\n']
>>> fo.close()

写入文件示例:

>>> fo = open("D:\\03-Study\\Python\\test\\test.txt", "w+")
>>> a = "Alex Lee"
>>> b = ["a", "b", "c"]
>>> fo.write(a)  #写入全部(write)
>>> fo.write("\n")    #换行符
>>> fo.writelines(b)    #写入列表,无换行符(writelines)
>>> for i in range(0, len(b)):
...     b[i] = b[i] + "\n"
...     
>>> print b
['a\n', 'b\n', 'c\n']
>>> fo.write("\n")    #换行符
>>> fo.writelines(b)    #写入列表,有换行符
>>> fo.close()
>>> fo = open("D:\\03-Study\\Python\\test\\test.txt", "r+")
>>> print fo.read()
Alex Lee
abc
a
b
c

 

02 File 对象 

====<<<< Description >>>>====

file 对象使用 open 函数来创建。
----------------------------------------------------------------------------------

====<<<< Properties >>>>====

◈   file.name:返回文件的名称。
◈   file.mode:返回被打开文件的访问模式。
◈   file.closed:返回true如果文件已被关闭,否则返回false。

----------------------------------------------------------------------------------

====<<<< Methods >>>>====

◈   file.writelines (sequence):向文件写入一个序列字符串列表,如果需要换行则要自己加入每行的换行符。
◈   file.write (str):将字符串写入文件,没有返回值。要自己加换行符
◈   file.truncate ([size]):用于截断文件,如果指定了可选参数 size,则表示截断文件为 size 个字符。 如果没有指定 size,则从当前位置起截断;截断之后 size 后面的所有字符被删除。
◈   file.tell ():返回文件的当前位置,即文件指针当前位置。
◈   file.seek (offset[, whence]):用于移动文件读取指针到指定位置。
◈   file.readlines ([sizeint]):读取所有行并返回列表,若给定sizeint>0,则是设置一次读多少字节,这是为了减轻读取压力。
◈   file.readline ([size]):读取整行,包括 "\n" 字符。
◈   file.read ([size]):从文件读取指定的字节数,如果未给定或为负则读取所有。
◈   file.next ():返回文件下一行。
◈   file.close ():关闭文件。关闭后文件不能再进行读写操作。
----------------------------------------------------------------------------------

====<<<< References >>>>====

参考:python中readline判断文件读取结束的方法

 
03 rename 方法 

 ====<<<< Description >>>>====

用于命名文件或目录,从 src 到 dst,如果dst是一个存在的目录, 将抛出OSError。(相当于移动文件)
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.rename (src, dst)
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  src:要修改的目录名。
◈  dst:修改后的目录名。

 
>>> import os
>>> os.rename(r"D:\test.txt", r"D:\test1.txt")
>>> os.rename(r"D:\test1.txt", r"D:\test2.txt")
04 remove 方法 

 ====<<<< Description >>>>====

用于删除指定路径的文件。如果指定的路径是一个目录,将抛出OSError。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.remove (path)
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  path:要移除的文件路径。

参考:python 删除文件、目录(shutil.rmtree())

 
# 实现删除文件夹内的HDF文件
import os
rootdir = r"D:\tmp\tmp"
for file in os.listdir(rootdir):
	if file.find("hdf") > 0:
		os.remove(os.path.join(rootdir, file))
 05mkdir 方法 

====<<<< Description >>>>====

用于以数字权限模式创建目录。默认的模式为 0777 (八进制)。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.mkdir (path[, mode])
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  path:要创建的目录。
◈  mode:要为目录设置的权限数字模式。

 
>>> import os
>>> os.mkdir(r"D:\folder")
 makedirs 方法 

====<<<< Description >>>>====

os.makedirs() 方法用于递归创建目录。像 mkdir(), 但创建的所有intermediate-level文件夹需要包含子目录。
----------------------------------------------------------------------------------

 

====<<<< Syntax >>>>====

 

os.makedirs (path[, mode])
----------------------------------------------------------------------------------

 

====<<<< Parameters >>>>====

 

◈  path:要创建的目录。
◈  mode:要为目录设置的权限数字模式。

 

  
 06chdir 方法 

====<<<< Description >>>>====

用于改变当前工作目录到指定的路径。(工作空间修改
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.chdir (path)
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  path:要切换到的新路径。

 
>>> import os
>>> print os.getcwd()
D:\01-Working\2018\20180115-浓烟专题图
>>> os.chdir(r"D:\03-Study\Python\test")
>>> os.rmdir("folder")
 
07 getcwd 方法 

====<<<< Description >>>>====

用于返回当前工作目录。(import sys)
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.getcwd ()

 
08 rmdir 方法 

====<<<< Description >>>>====

用于删除指定路径的目录。仅当这文件夹是空的才可以, 否则, 抛出OSError。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.rmdir (path)
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  path:要删除的目录路径。

 
 09listdir 方法 

====<<<< Description >>>>====

用于返回指定的文件夹包含的文件或文件夹的名字的列表。这个列表以字母顺序。 它不包括 '.' 和'..' 即使它在文件夹中。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>====

os.listdir (path)
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  path:需要列出的目录路径。

 
>>> import os
>>> print os.listdir(r"D:\test")
['11.txt', 'cnblog1.txt', 'frame.ui']
10input 方法 

====<<<< Description >>>>====

Python3.x 中 input() 函数接受一个标准输入数据,返回为 string 类型。
Python2.x 中 input() 相等于 eval(raw_input(prompt)) ,用来获取控制台的输入。
raw_input() 将所有输入作为字符串看待,返回字符串类型。而 input() 在对待纯数字输入时具有自己的特性,它返回所输入的数字的类型( int, float )。

注意:input() 和 raw_input() 这两个函数均能接收 字符串 ,但 raw_input() 直接读取控制台的输入(任何类型的输入它都可以接收)。而对于 input() ,它希望能够读取一个合法的 python 表达式,即你输入字符串的时候必须使用引号将它括起来,否则它会引发一个 SyntaxError 。
除非对 input() 有特别需要,否则一般情况下我们都是推荐使用 raw_input() 来与用户交互。
----------------------------------------------------------------------------------

====<<<< Syntax >>>>===

input ([prompt])
----------------------------------------------------------------------------------

====<<<< Parameters >>>>====

◈  prompt:可选,字符串,可作为一个提示语。

 
>>> a = input("input:")
input:123
>>> type(a)
<type 'int'>
>>> a
123
>>> a = input("input:")
input:"alex"
>>> a
'alex'
>>> a = input("input:")
input:alex

Traceback (most recent call last):
  File "<pyshell#23>", line 1, in <module>
    a = input("input:")
  File "<string>", line 1, in <module>
NameError: name 'alex' is not defined
11raw_input 方法 

====<<<< Description >>>>====

用来获取控制台的输入。
将所有输入作为字符串看待,返回字符串类型。
----------------------------------------------------------------------------------

 

====<<<< Syntax >>>>====

 

raw_input ([prompt])
----------------------------------------------------------------------------------

 

====<<<< Parameters >>>>====

 

◈  prompt:可选,字符串,可作为一个提示语。

 

 
>>> a = raw_input("input:")
input:123
>>> type(a)
<type 'str'>
>>> a
'123'
>>> a = raw_input("input:")
input:alex
>>> a
'alex'
------------------------------------    

转载于:https://www.cnblogs.com/alex-bn-lee/p/8280916.html

相关文章:

  • Model to Text工具Acceleo使用教程(三)——一个简单的代码生成模块
  • UVa11426 最大公约数之和(正版)
  • mac os下通过命令行的方式编译c++代码并在xcode里引用
  • 房地产英语 Real estate词汇
  • 根据Forms名找出其所归属的权限组
  • oss web直传
  • dd-wrt达到300Mbps的关键设置
  • 跨域
  • [转载] 考试经验——2011下半年信息系统项目管理师论文52分者谈论文写作经验...
  • 『TensorFlow』TFR数据预处理探究以及框架搭建
  • shell开发基础:准备100万条测试数据在MYSQL中
  • 十个生成模型(GANs)的最佳案例和原理 | 代码+论文
  • Linux中如何让进程(或正在运行的程序)到后台运行?[zz]
  • Spring Boot快速入门(一):Hello Spring Boot
  • 一致性hash
  • Android 初级面试者拾遗(前台界面篇)之 Activity 和 Fragment
  • Docker下部署自己的LNMP工作环境
  • IP路由与转发
  • java取消线程实例
  • Java应用性能调优
  • JS笔记四:作用域、变量(函数)提升
  • Mac转Windows的拯救指南
  • Magento 1.x 中文订单打印乱码
  • mockjs让前端开发独立于后端
  • Mybatis初体验
  • spring boot下thymeleaf全局静态变量配置
  • Spring Cloud中负载均衡器概览
  • web标准化(下)
  • 使用 QuickBI 搭建酷炫可视化分析
  • 想写好前端,先练好内功
  • 云栖大讲堂Java基础入门(三)- 阿里巴巴Java开发手册介绍
  • 06-01 点餐小程序前台界面搭建
  • ​Java并发新构件之Exchanger
  • ​决定德拉瓦州地区版图的关键历史事件
  • ​一些不规范的GTID使用场景
  • $(function(){})与(function($){....})(jQuery)的区别
  • (2.2w字)前端单元测试之Jest详解篇
  • (4)事件处理——(7)简单事件(Simple events)
  • (9)目标检测_SSD的原理
  • (C#)获取字符编码的类
  • (办公)springboot配置aop处理请求.
  • (大众金融)SQL server面试题(1)-总销售量最少的3个型号的车及其总销售量
  • (附源码)计算机毕业设计大学生兼职系统
  • (十五)使用Nexus创建Maven私服
  • (一)基于IDEA的JAVA基础12
  • .net Application的目录
  • .net core开源商城系统源码,支持可视化布局小程序
  • .net redis定时_一场由fork引发的超时,让我们重新探讨了Redis的抖动问题
  • .net wcf memory gates checking failed
  • .Net 路由处理厉害了
  • .NET框架
  • .NET项目中存在多个web.config文件时的加载顺序
  • .NET应用架构设计:原则、模式与实践 目录预览
  • //解决validator验证插件多个name相同只验证第一的问题
  • /dev下添加设备节点的方法步骤(通过device_create)