python inp文件_python 文件操作

"""

r

w

a

将上面的三个模式称为纯净模式

r+

w+

a+

"""

打印到屏幕

最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式。此函数把你传递的表达式转换成一个字符串表达式,并将结果写到标准输出如下:

#!/usr/bin/python# -*- coding: UTF-8 -*- print"Python 是一个非常棒的语言,不是吗?"

你的标准屏幕上会产生以下结果:

Python是一个非常棒的语言,不是吗?

读取键盘输入

Python提供了两个内置函数从标准输入读入一行文本,默认的标准输入是键盘。如下:

raw_input

input

raw_input函数

raw_input([prompt]) 函数从标准输入读取一个行,并返回一个字符串(去掉结尾的换行符):

#!/usr/bin/python# -*- coding: UTF-8 -*- str =raw_input("请输入:")print"你输入的内容是: ",str

这将提示你输入任意字符串,然后在屏幕上显示相同的字符串。当我输入"Hello Python!",它的输出如下:

请输入:HelloPython!你输入的内容是:HelloPython!

input函数

input([prompt]) 函数和 raw_input([prompt]) 函数基本类似,但是 input 可以接收一个Python表达式作为输入,并将运算结果返回。

#!/usr/bin/python# -*- coding: UTF-8 -*- str =input("请输入:")print"你输入的内容是: ",str

这会产生如下的对应着输入的结果:

请输入:[x*5forx inrange(2,10,2)]你输入的内容是:[10,20,30,40]

打开和关闭文件

现在,您已经可以向标准输入和输出进行读写。现在,来看看怎么读写实际的数据文件。

Python 提供了必要的函数和方法进行默认情况下的文件基本操作。你可以用 file 对象做大部分的文件操作。

open 函数

你必须先用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。

语法:

file object=open(file_name [,access_mode][,buffering])

各个参数的细节如下:

file_name:file_name变量是一个包含了你要访问的文件名称的字符串值。

access_mode:access_mode决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。

buffering:如果buffering的值被设为0,就不会有寄存。如果buffering的值取1,访问文件时会寄存行。如果将buffering的值设为大于1的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。

不同模式打开文件的完全列表:

模式描述

t

文本模式 (默认)。

x

写模式,新建一个文件,如果该文件已存在则会报错。

b

二进制模式。

+

打开一个文件进行更新(可读可写)。

U

通用换行模式(不推荐)。

r

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

rb

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

r+

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

rb+

以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。

w

打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb

以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

w+

打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb+

以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

a

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

ab

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

a+

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

ab+

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

下图很好的总结了这几种模式:

模式rr+ww+aa+

+

+

+

+

+

+

+

+

+

创建

+

+

+

+

覆盖

+

+

指针在开始

+

+

+

+

指针在结尾

+

+

File对象的属性

一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。

以下是和file对象相关的所有属性的列表:

属性描述

file.closed

返回true如果文件已被关闭,否则返回false。

file.mode

返回被打开文件的访问模式。

file.name

返回文件的名称。

file.softspace

如果用print输出后,必须跟一个空格符,则返回false。否则返回true。

如下实例:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")print"文件名: ",fo.name

print"是否已关闭 : ",fo.closed

print"访问模式 : ",fo.mode

print"末尾是否强制加空格 : ",fo.softspace

以上实例输出结果:

文件名:foo.txt

是否已关闭:False访问模式:w

末尾是否强制加空格:0

close()方法

File 对象的 close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。

当一个文件对象的引用被重新指定给另一个文件时,Python 会关闭之前的文件。用 close()方法关闭文件是一个很好的习惯。

语法:

fileObject.close()

例子:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")print"文件名: ",fo.name

# 关闭打开的文件fo.close()

以上实例输出结果:

文件名:foo.txt

读写文件:

file对象提供了一系列方法,能让我们的文件访问更轻松。来看看如何使用read()和write()方法来读取和写入文件。

write()方法

write()方法可将任何字符串写入一个打开的文件。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。

write()方法不会在字符串的结尾添加换行符('\n'):

语法:

fileObject.write(string)

在这里,被传递的参数是要写入到已打开文件的内容。

例子:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")fo.write("www.runoob.com!\nVery good site!\n")# 关闭打开的文件fo.close()

上述方法会创建foo.txt文件,并将收到的内容写入该文件,并最终关闭文件。如果你打开这个文件,将看到以下内容:

$ cat foo.txt

www.runoob.com!Verygood site!

read()方法

read()方法从一个打开的文件中读取一个字符串。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。

语法:

fileObject.read([count])

在这里,被传递的参数是要从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,很可能是直到文件的末尾。

例子:

这里我们用到以上创建的 foo.txt 文件。

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","r+")str =fo.read(10)print"读取的字符串是 : ",str

# 关闭打开的文件fo.close()

以上实例输出结果:

读取的字符串是:www.runoob

文件位置:

文件定位

tell()方法告诉你文件内的当前位置, 换句话说,下一次的读写会发生在文件开头这么多字节之后。

seek(offset [,from])方法改变当前文件的位置。Offset变量表示要移动的字节数。From变量指定开始移动字节的参考位置。

如果from被设为0,这意味着将文件的开头作为移动字节的参考位置。如果设为1,则使用当前的位置作为参考位置。如果它被设为2,那么该文件的末尾将作为参考位置。

例子:

就用我们上面创建的文件foo.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","r+")str =fo.read(10)print"读取的字符串是 : ",str

# 查找当前位置position =fo.tell()print"当前文件位置 : ",position

# 把指针再次重新定位到文件开头position =fo.seek(0,0)str =fo.read(10)print"重新读取字符串 : ",str

# 关闭打开的文件fo.close()

以上实例输出结果:

读取的字符串是:www.runoob

当前文件位置:10重新读取字符串:www.runoob

重命名和删除文件

Python的os模块提供了帮你执行文件处理操作的方法,比如重命名和删除文件。

要使用这个模块,你必须先导入它,然后才可以调用相关的各种功能。

rename()方法:

rename()方法需要两个参数,当前的文件名和新文件名。

语法:

os.rename(current_file_name,new_file_name)

例子:

下例将重命名一个已经存在的文件test1.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 重命名文件test1.txt到test2.txt。os.rename("test1.txt","test2.txt")

remove()方法

你可以用remove()方法删除文件,需要提供要删除的文件名作为参数。

语法:

os.remove(file_name)

例子:

下例将删除一个已经存在的文件test2.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 删除一个已经存在的文件test2.txtos.remove("test2.txt")

Python里的目录:

所有文件都包含在各个不同的目录下,不过Python也能轻松处理。os模块有许多方法能帮你创建,删除和更改目录。

mkdir()方法

可以使用os模块的mkdir()方法在当前目录下创建新的目录们。你需要提供一个包含了要创建的目录名称的参数。

语法:

os.mkdir("newdir")

例子:

下例将在当前目录下创建一个新目录test。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 创建目录testos.mkdir("test")

chdir()方法

可以用chdir()方法来改变当前的目录。chdir()方法需要的一个参数是你想设成当前目录的目录名称。

语法:

os.chdir("newdir")

例子:

下例将进入"/home/newdir"目录。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 将当前目录改为"/home/newdir"os.chdir("/home/newdir")

getcwd()方法:

getcwd()方法显示当前的工作目录。

语法:

os.getcwd()

例子:

下例给出当前目录:

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 给出当前的目录printos.getcwd()

rmdir()方法

rmdir()方法删除目录,目录名称以参数传递。

在删除这个目录之前,它的所有内容应该先被清除。

语法:

os.rmdir('dirname')

例子:

以下是删除" /tmp/test"目录的例子。目录的完全合规的名称必须被给出,否则会在当前目录下搜索该目录。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 删除”/tmp/test”目录os.rmdir("/tmp/test")

文件、目录相关的方法

File 对象和 OS 对象提供了很多文件与目录的操作方法,可以通过点击下面链接查看详情:

File 对象方法: file 对象提供了操作文件的一系列方法。

OS 对象方法: 提供了处理文件及目录的一系列方法。

# with open(r'test',mode='r+',encoding='utf-8') as f:

# print(f.readable())

# print(f.writable())

# print(f.readline())

# f.write('嘿嘿嘿')

# with open(r'test',mode='w+',encoding='utf-8') as f:

# print(f.readable())

# print(f.writable())

# print(f.readline())

# f.write('嘿嘿嘿')

# with open(r'test',mode='r+b') as f:

# print(f.readable())

# print(f.writable())

# res = f.read()

# # print(res.decode('utf-8'))

# res1 = str(res,encoding='utf-8')

# print(res1)

# 在rt模式下 read内的数字 表示的是字符的个数

# 初次之外,数字表示的都是字节

# with open(r'test','r',encoding='utf-8') as f:

# print(f.read(5))

# with open(r'test','rb') as f:

# res = f.read(10) # 读的是三个字节bytes

# print(res)

# print(res.decode('utf-8'))

# 文件内光标的移动

"""

f.seek(offset,whence)

offset:相对偏移量 光标移动的位数

whence:

0:参照文件的开头 t和b都可以使用

1:参照光标所在的当前位置 只能在b模式下用

2:参照文件的末尾 只能在b模式下使用

"""

# with open(r'test','rt',encoding='utf-8') as f:

# print(f.read(1))

# # f.seek(6,0) # seek移动都是字节数

# # f.seek(4,0) # seek移动都是字节数

# # print(f.read(1))

# f.seek(0,0)

# print(f.read(1))

# f.seek(0, 0)

# print(f.read(1))

# f.seek(6,0)

# print(f.read())

# with open(r'test','rb') as f:

# print(f.read(3).decode('utf-8'))

# f.seek(0,0)

# print(f.read(3).decode('utf-8'))

# f.seek(7,0)

# print(f.read(1).decode('utf-8'))

# # f.seek(6,0) # seek移动都是字节数

# # f.seek(4,0) # seek移动都是字节数

# with open(r'test','rb') as f:

# print(f.read(3).decode('utf-8'))

# f.seek(3,1)

# print(f.read(1))

# f.seek(6,0) # seek移动都是字节数

# f.seek(4,0) # seek移动都是字节数

# with open(r'test','rb') as f:

# print(f.read())

# f.seek(-4,2)

# print(f.read().decode('utf-8'))

# with open(r'test','r+',encoding='utf-8') as f:

# f.seek(3,0)

# f.write('过')

# 在rt模式下 read内的数字 表示的是字符的个数

# 初次之外,数字表示的都是字节

# with open(r'test','r',encoding='utf-8') as f:

# print(f.read(5))

# with open(r'test','rb') as f:

# res = f.read(10) # 读的是三个字节bytes

# print(res)

# print(res.decode('utf-8'))

# 文件内光标的移动

"""

f.seek(offset,whence)

offset:相对偏移量 光标移动的位数

whence:

0:参照文件的开头 t和b都可以使用

1:参照光标所在的当前位置 只能在b模式下用

2:参照文件的末尾 只能在b模式下使用

"""

# with open(r'test','rt',encoding='utf-8') as f:

# print(f.read(1))

# # f.seek(6,0) # seek移动都是字节数

# # f.seek(4,0) # seek移动都是字节数

# # print(f.read(1))

# f.seek(0,0)

# print(f.read(1))

# f.seek(0, 0)

# print(f.read(1))

# f.seek(6,0)

# print(f.read())

# with open(r'test','rb') as f:

# print(f.read(3).decode('utf-8'))

# f.seek(0,0)

# print(f.read(3).decode('utf-8'))

# f.seek(7,0)

# print(f.read(1).decode('utf-8'))

# # f.seek(6,0) # seek移动都是字节数

# # f.seek(4,0) # seek移动都是字节数

# with open(r'test','rb') as f:

# print(f.read(3).decode('utf-8'))

# f.seek(3,1)

# print(f.read(1))

# f.seek(6,0) # seek移动都是字节数

# f.seek(4,0) # seek移动都是字节数

# with open(r'test','rb') as f:

# print(f.read())

# f.seek(-4,2)

# print(f.read().decode('utf-8'))

# with open(r'test','r+',encoding='utf-8') as f:

# f.seek(3,0)

# f.write('过')

with open(r'test01.txt','rb') as f:

# 先将光标移动到文件末尾

f.seek(0,2)

while True:

res = f.readline()

# 查看光标移动了多少位 bytes

# print(f.tell())

if res:

print("新增的文件内容:%s"%res.decode('utf-8'))

# 说明有人操作当前文件

# else:

# # 说明文件没有被任何人操作

# print('暂无其他人操作该文件')

with open(r'test','a',encoding='utf-8') as f:

f.truncate(6) # 接收的字节的长度 整型

# 保留0~6字节数 后面的全部删除(截断)

# with open(r'test','r+',encoding='utf-8') as f:

# f.seek(6,0)

# f.write('h')

# 修改文件

# 先将数据由硬盘读到内存(读文件)

# 在内存中完成修改(字符串的替换)

# 再覆盖原来的内容(写文件)

# with open(r'test02.txt','r',encoding='utf-8') as f:

# data = f.read()

# print(data)

# print(type(data))

#

# with open(r'test02.txt','w',encoding='utf-8') as f:

# res = data.replace('egon','jason')

# print(data)

# f.write(res)

"""

优点:任意时间硬盘上只有一个文件 不会占用过多硬盘空间

缺点:当文件过大的情况下,可能会造成内存溢出

"""

# 文件修改方式2

# 创建一个新文件

# 循环读取老文件内容到内存进行修改 将修改好的内容写到新文件中

# 将老文件删除 将新文件的名字改成老文件名

import os

with open(r'test02.txt','r',encoding='utf-8') as read_f,\

open(r'test02.swap','a',encoding='utf-8') as write_f:

for line in read_f:

new_line = line.replace('jason','egon')

write_f.write(new_line)

os.remove('test02.txt')

os.rename('test02.swap','test02.txt')

"""

优点:内存中始终只有一行内容 不占内存

缺点:再某一时刻硬盘上会同时存在两个文件

每日默写

修改文件的两种方式

加上你自己的逻辑思维

"""

s = 'hello'

# print(len(s))

# 假设没有len了

# 函数体代码定义截断只检测语法 不执行代码

def test():

hdhfd

sdafsd

sdafjsldakj

sdfljsda;lf;lskdf;l

print(test() )

"""

可以通过变量名找到变量对应的值

可以通过函数名+括号 找到函数体所对应的代码并执行

"""

# 函数名的命名规则跟变量名一模一样

# 函数就是工具,并且函数必须先定义后调用(函数名+括号)

# def my_len():

# n = 0

# for i in s:

# n += 1

# print(n)

# my_len()

# my_len()

# my_len()

# l = [1,2,3,4,5]

# m = 0

# for j in l:

# m += 1

# print(m)

# 将for循环的代码放到某一个地方 谁要用谁就拿

已下是摘录自runoob的io操作拓展

打印到屏幕

最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式。此函数把你传递的表达式转换成一个字符串表达式,并将结果写到标准输出如下:

#!/usr/bin/python# -*- coding: UTF-8 -*- print"Python 是一个非常棒的语言,不是吗?"

你的标准屏幕上会产生以下结果:

Python是一个非常棒的语言,不是吗?

读取键盘输入

Python提供了两个内置函数从标准输入读入一行文本,默认的标准输入是键盘。如下:

raw_input

input

raw_input函数

raw_input([prompt]) 函数从标准输入读取一个行,并返回一个字符串(去掉结尾的换行符):

#!/usr/bin/python# -*- coding: UTF-8 -*- str =raw_input("请输入:")print"你输入的内容是: ",str

这将提示你输入任意字符串,然后在屏幕上显示相同的字符串。当我输入"Hello Python!",它的输出如下:

请输入:HelloPython!你输入的内容是:HelloPython!

input函数

input([prompt]) 函数和 raw_input([prompt]) 函数基本类似,但是 input 可以接收一个Python表达式作为输入,并将运算结果返回。

#!/usr/bin/python# -*- coding: UTF-8 -*- str =input("请输入:")print"你输入的内容是: ",str

这会产生如下的对应着输入的结果:

请输入:[x*5forx inrange(2,10,2)]你输入的内容是:[10,20,30,40]

打开和关闭文件

现在,您已经可以向标准输入和输出进行读写。现在,来看看怎么读写实际的数据文件。

Python 提供了必要的函数和方法进行默认情况下的文件基本操作。你可以用 file 对象做大部分的文件操作。

open 函数

你必须先用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写。

语法:

file object=open(file_name [,access_mode][,buffering])

各个参数的细节如下:

file_name:file_name变量是一个包含了你要访问的文件名称的字符串值。

access_mode:access_mode决定了打开文件的模式:只读,写入,追加等。所有可取值见如下的完全列表。这个参数是非强制的,默认文件访问模式为只读(r)。

buffering:如果buffering的值被设为0,就不会有寄存。如果buffering的值取1,访问文件时会寄存行。如果将buffering的值设为大于1的整数,表明了这就是的寄存区的缓冲大小。如果取负值,寄存区的缓冲大小则为系统默认。

不同模式打开文件的完全列表:

模式描述

t

文本模式 (默认)。

x

写模式,新建一个文件,如果该文件已存在则会报错。

b

二进制模式。

+

打开一个文件进行更新(可读可写)。

U

通用换行模式(不推荐)。

r

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

rb

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

r+

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

rb+

以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。一般用于非文本文件如图片等。

w

打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb

以二进制格式打开一个文件只用于写入。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

w+

打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。

wb+

以二进制格式打开一个文件用于读写。如果该文件已存在则打开文件,并从开头开始编辑,即原有内容会被删除。如果该文件不存在,创建新文件。一般用于非文本文件如图片等。

a

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

ab

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

a+

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

ab+

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

下图很好的总结了这几种模式:

模式rr+ww+aa+

+

+

+

+

+

+

+

+

+

创建

+

+

+

+

覆盖

+

+

指针在开始

+

+

+

+

指针在结尾

+

+

File对象的属性

一个文件被打开后,你有一个file对象,你可以得到有关该文件的各种信息。

以下是和file对象相关的所有属性的列表:

属性描述

file.closed

返回true如果文件已被关闭,否则返回false。

file.mode

返回被打开文件的访问模式。

file.name

返回文件的名称。

file.softspace

如果用print输出后,必须跟一个空格符,则返回false。否则返回true。

如下实例:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")print"文件名: ",fo.name

print"是否已关闭 : ",fo.closed

print"访问模式 : ",fo.mode

print"末尾是否强制加空格 : ",fo.softspace

以上实例输出结果:

文件名:foo.txt

是否已关闭:False访问模式:w

末尾是否强制加空格:0

close()方法

File 对象的 close()方法刷新缓冲区里任何还没写入的信息,并关闭该文件,这之后便不能再进行写入。

当一个文件对象的引用被重新指定给另一个文件时,Python 会关闭之前的文件。用 close()方法关闭文件是一个很好的习惯。

语法:

fileObject.close()

例子:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")print"文件名: ",fo.name

# 关闭打开的文件fo.close()

以上实例输出结果:

文件名:foo.txt

读写文件:

file对象提供了一系列方法,能让我们的文件访问更轻松。来看看如何使用read()和write()方法来读取和写入文件。

write()方法

write()方法可将任何字符串写入一个打开的文件。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。

write()方法不会在字符串的结尾添加换行符('\n'):

语法:

fileObject.write(string)

在这里,被传递的参数是要写入到已打开文件的内容。

例子:

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","w")fo.write("www.runoob.com!\nVery good site!\n")# 关闭打开的文件fo.close()

上述方法会创建foo.txt文件,并将收到的内容写入该文件,并最终关闭文件。如果你打开这个文件,将看到以下内容:

$ cat foo.txt

www.runoob.com!Verygood site!

read()方法

read()方法从一个打开的文件中读取一个字符串。需要重点注意的是,Python字符串可以是二进制数据,而不是仅仅是文字。

语法:

fileObject.read([count])

在这里,被传递的参数是要从已打开文件中读取的字节计数。该方法从文件的开头开始读入,如果没有传入count,它会尝试尽可能多地读取更多的内容,很可能是直到文件的末尾。

例子:

这里我们用到以上创建的 foo.txt 文件。

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","r+")str =fo.read(10)print"读取的字符串是 : ",str

# 关闭打开的文件fo.close()

以上实例输出结果:

读取的字符串是:www.runoob

文件位置:

文件定位

tell()方法告诉你文件内的当前位置, 换句话说,下一次的读写会发生在文件开头这么多字节之后。

seek(offset [,from])方法改变当前文件的位置。Offset变量表示要移动的字节数。From变量指定开始移动字节的参考位置。

如果from被设为0,这意味着将文件的开头作为移动字节的参考位置。如果设为1,则使用当前的位置作为参考位置。如果它被设为2,那么该文件的末尾将作为参考位置。

例子:

就用我们上面创建的文件foo.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-# 打开一个文件fo =open("foo.txt","r+")str =fo.read(10)print"读取的字符串是 : ",str

# 查找当前位置position =fo.tell()print"当前文件位置 : ",position

# 把指针再次重新定位到文件开头position =fo.seek(0,0)str =fo.read(10)print"重新读取字符串 : ",str

# 关闭打开的文件fo.close()

以上实例输出结果:

读取的字符串是:www.runoob

当前文件位置:10重新读取字符串:www.runoob

重命名和删除文件

Python的os模块提供了帮你执行文件处理操作的方法,比如重命名和删除文件。

要使用这个模块,你必须先导入它,然后才可以调用相关的各种功能。

rename()方法:

rename()方法需要两个参数,当前的文件名和新文件名。

语法:

os.rename(current_file_name,new_file_name)

例子:

下例将重命名一个已经存在的文件test1.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 重命名文件test1.txt到test2.txt。os.rename("test1.txt","test2.txt")

remove()方法

你可以用remove()方法删除文件,需要提供要删除的文件名作为参数。

语法:

os.remove(file_name)

例子:

下例将删除一个已经存在的文件test2.txt。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 删除一个已经存在的文件test2.txtos.remove("test2.txt")

Python里的目录:

所有文件都包含在各个不同的目录下,不过Python也能轻松处理。os模块有许多方法能帮你创建,删除和更改目录。

mkdir()方法

可以使用os模块的mkdir()方法在当前目录下创建新的目录们。你需要提供一个包含了要创建的目录名称的参数。

语法:

os.mkdir("newdir")

例子:

下例将在当前目录下创建一个新目录test。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 创建目录testos.mkdir("test")

chdir()方法

可以用chdir()方法来改变当前的目录。chdir()方法需要的一个参数是你想设成当前目录的目录名称。

语法:

os.chdir("newdir")

例子:

下例将进入"/home/newdir"目录。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 将当前目录改为"/home/newdir"os.chdir("/home/newdir")

getcwd()方法:

getcwd()方法显示当前的工作目录。

语法:

os.getcwd()

例子:

下例给出当前目录:

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 给出当前的目录printos.getcwd()

rmdir()方法

rmdir()方法删除目录,目录名称以参数传递。

在删除这个目录之前,它的所有内容应该先被清除。

语法:

os.rmdir('dirname')

例子:

以下是删除" /tmp/test"目录的例子。目录的完全合规的名称必须被给出,否则会在当前目录下搜索该目录。

#!/usr/bin/python# -*- coding: UTF-8 -*-importos

# 删除”/tmp/test”目录os.rmdir("/tmp/test")

文件、目录相关的方法

File 对象和 OS 对象提供了很多文件与目录的操作方法,可以通过点击下面链接查看详情:

File 对象方法: file 对象提供了操作文件的一系列方法。

OS 对象方法: 提供了处理文件及目录的一系列方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值