IO(文件)处理

一、文件处理简介

计算机系统分为:计算机硬件,操作系统,应用程序三部分。

我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应用程序是无法直接操作硬件的,这就用到了操作系统。操作系统把复杂的硬件操作封装成简单的接口给用户/应用程序使用,其中文件就是操作系统提供给应用程序来操作硬盘虚拟概念,用户或应用程序通过操作文件,可以将自己的数据永久保存下来。

有了文件的概念,我们无需再去考虑操作硬盘的细节,只需要关注操作文件的流程:

#1. 打开文件,得到文件句柄并赋值给一个变量
#2. 通过句柄对文件进行操作
#3. 关闭文件

二、打开文件的方法

① f = open('文件名' , '操作模式' , ‘编码格式’)  如:

f = open('test.txt','r',encoding='utf-8')

注意:用这种方法打开文件,用完之后一定要调用f.close()方法将其关闭

 

②with open('文件名' , '操作模式' , ‘编码格式’)  as f 如:

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

注意:用这种方法打开文件,处理完后会自动关闭文件,但是处理的段落要进行缩进

三、操作文件的几种模式

 

四、处理文件的几种方法

示例文件如下:

 

 

△读文件:

read( )

读取整个文件

1 with open('love.txt','r',encoding='utf-8') as f:
2     msg = f.read()
3     print(msg)

 

read( int )

read()方法可以指定读取的字符数,注意,是字符数,不是字节数,如下:

1 with open('love.txt','r',encoding='utf-8') as f:
2     msg = f.read()
3     print(msg)
#结果为‘一生所’

 

readline( )

可以读取一行,如下:

1 with open('love.txt','r',encoding='utf-8') as f:
2     msg = f.readline()
3     print(msg)
#结果是 ‘一生所爱’

 

readlines( )

可以读取整篇文章,并且将每一行都作为一个元素添加到一个列表中,如下:

with open('love.txt','r',encoding='utf-8') as f:
    msg = f.readlines()
    print(msg)
#结果是:['一生所爱\n', '演唱:卢冠庭\n', '从前现在过去了再不来\n', 
     '红红落叶长埋尘土内\n', '开始终结总是没变改\n', '天边的你飘泊白云外\n', 
     '苦海翻起爱恨\n', '在世间难逃避命运\n', '相亲竟不可接近\n', '或我应该相信是缘份']

 

for lin in f :

可以用循环的方法直接读取每一行。f 是一个可迭代对象

 1 with open('love.txt','r',encoding='utf-8') as f:
 2     for line in f:
 3         print(line,end='')
 4 #结果是:
 5 # 一生所爱
 6 # 演唱:卢冠庭
 7 # 从前现在过去了再不来
 8 # 红红落叶长埋尘土内
 9 # 开始终结总是没变改
10 # 天边的你飘泊白云外
11 # 苦海翻起爱恨
12 # 在世间难逃避命运
13 # 相亲竟不可接近
14 # 或我应该相信是缘份

 

△写文件:

write( str )

可以指定写入模式,如果文件不存在,重新创建一个,如果已经存在,w模式下会将之前的文字覆盖,重新写入,a模式是在结尾处追加。

1 with open('love.txt','w',encoding='utf-8') as f:
2     f.write('这段话会覆盖之前的文章')

3 with open('love.txt','a',encoding='utf-8') as f:
4 f.write('这段话不会覆盖之前的文章')

 

△光标的移动

seek( )

语法为:fileObject.seek(offset, whence)
  • offset -- 开始的偏移量,也就是代表需要移动偏移的字节数,注意,是字节数,负数表示像前移动

  • whence:可选,默认值为 0。给offset参数一个定义,表示要从哪个位置开始偏移;0代表从文件开头开始算起,1代表从当前位置开始算起,2代表从文件末尾算起。

1 with open('love.txt','r',encoding='utf-8') as f:
2     print(f.read(3)) #读取3个字符 : 一生所
3     f.seek(3)        #光标从起点向后移3个字节(1个中文)
4     print(f.read(3)) #再从前面的基础上开始读:生所爱

tell( )

可以获取当前光标位置,返回的是字节数

 

△截取文件

 truncate()

此方法是截取文件,注意,是直接对原文件进行截取。参数是填一个字节数,如下:

1 with open('love.txt','r+',encoding='utf-8') as f:
2     f.truncate(9)    #截取9个字节,就是3个中文
3     print(f.read())   #再读取的内容结果为:一生所  3个字

 

五:应用练习(注册,登录小系统)

 1 #用户注册,将用户名以及密码存在文件里,然后验证登录信息,给3次机会
 2 print('*************注册信息*************')
 3 while 1:
 4     username = input('请输入您的用户名:').strip()
 5     password = ''
 6     password1 = input('请输入您的注册密码:').strip()
 7     password2 = input('请再次输入您的注册密码:').strip()
 8     if password1 == password2:
 9         print('恭喜您,注册成功!')
10         password = password1
11         break
12     else:
13         print('您两次输入的密码不同,请重新输入!')
14 with open('day8.txt','w',encoding='utf-8') as f1:
15 
16     # f1.write('{%s:%s}'%(username,password))
17     f1.write('%s:%s'%(username,password))
18 
19 print('*************登录信息*************')
20 
21 count = 3
22 with open('day8.txt','r',encoding='utf-8') as f2:
23     user_list = f2.read().split(':')
24 
25     # print(user_list)
26     while count > 0 :
27         username = input('请输入您的用户名:').strip()
28         password = input('请输入您的密码:').strip()
29         if username == user_list[0] and password == user_list[1]:
30             print('恭喜您,登陆成功!')
31             break
32         else:
33             count -= 1
34             print('登录失败,请重新输入!您还有%s次机会'%count)

 

posted @ 2017-12-25 20:14  人生不如戏  阅读(1015)  评论(0编辑  收藏  举报