机器学习之python学习(十九)

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_33094993/article/details/78994456

今天来学习python中的文件操作这是很关键的,
这次先学习文件的读写,需要注意的是文件的权限的问题。
总结如下最常用的权限:

权限 数量
r 打开只读文件,该文件必须存在。
w 打开只写文件,若文件存在则文件长度清为0, 即该文件内容会消失。若文件不存在则建立该文件。
r+ 打开可读写的文件,该文件必须存在。
w+ 打开可读写文件,若文件存在则文件长度清为零,即该文件内容会消失。若文件不存在则建立该文件。
a 以附加的方式打开只写文件。若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾,即文件原先的内容会被保留。
a+ 以附加方式打开可读写的文件。 若文件不存在,则会建立该文件,如果文件存在,写入的数据会被加到文件尾后,即文件原先的内容会被保留。

总结下来有+的均可以读写。

你们也可以参考廖雪峰大神的python教学快速入门。

代码块

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Author  : SundayCoder-俊勇
# @File    : filelearn.py
# 今天我们来学习一下python中文件的操作。
# 很多机器学习需要读入csv文件
# 所以文件的操作是机器学习必须学会的一个技能
# (1)文件的打开和关闭[不标准的写法]
f=open('hello.txt','r')
print f.read()
f.close()
# 文件的操作的最后一步必须是关闭文件。
# 因为read()函数是一次性输出文件的所有数据
# 所以输出结果为:
# hello wolrd
# 你好啊
# (2)文件打开过程中会有错误,所以可以使用try-finally来处理错误
# 文件的打开与关闭的标准写法。
try:
    f = open('hello.txt', 'r')
    print f.read()
finally:
    if f:#如果f存在则关闭
        f.close()
# (3)文件的打开和关闭每次都这么写实在太繁琐,
# 所以,Python引入了with语句来自动帮我们调用close()方法:
with open('hello.txt', 'r') as f:
    print f.read()
# 注:第三种是最常用的一种方法,必须要掌握的方法。
# (4)如果打开的文件不存在则会报错:
# with open('hello1.txt', 'r') as f:
#     print f.read()
# 报错的内容为:IOError: [Errno 2] No such file or directory: 'hello1.txt'
# 报错会提示你打开的文件不存在。
# (5)读取文件的方法的比较。
# 调用read()会一次性读取文件的全部内容,
# 如果文件有10G,内存就爆了,所以,
# 要保险起见,可以反复调用read(size)方法,
# 每次最多读取size个字节的内容。
# 另外,调用readline()可以每次读取一行内容,
# 调用readlines()一次读取所有内容并按行返回list。
# 因此,要根据需要决定怎么调用。
# 如果文件很小,read()一次性读取最方便;
# 如果不能确定文件大小,反复调用read(size)比较保险;
# 如果是配置文件,调用readlines()最方便:

# 例如:
with open('hello.txt', 'r') as f:
    print f.read(2)
# 输出的结果为:he
# 注:英文字母一个占一个字节,中文一个占两个字节。


# 读取文件最最常用的一种方法。
with open('hello.txt', 'r') as f:
   for line in f.readlines():#每次读取一行
       print(line.strip()) # 把每一个行的末尾的'\n'删掉
# 输出的结果:
# hello wolrd
# 你好啊
# (8)文件的写操作。
# fp.write(str) #把str写到文件中,
# write()并不会在str后加上一个换行符
# fp.writelines(seq) #把seq的内容全部写到文件中
# (多行一次性写入)这个函数也只是忠实地写入,不会在每行后面加上任何东西。

with open('hello1.txt', 'w') as f:
    f.write("this is  new content")
    # 写入之后重新查看文档内容
with open('hello1.txt', 'r') as f:
    for line in f.readlines():  # 每次读取一行
        print(line.strip())  # 把每一个行的末尾的'\n'删掉
# 输出的结果为:this is  new content
# 说明原来的内容已经被覆盖掉了,这与文章的权限有关。
#文章的权限总结如下:
# (1)r 打开只读文件,该文件必须存在。
# (2)r+ 打开可读写的文件,该文件必须存在。
# (3)w 打开只写文件,若文件存在则文件长度清为0,
# 即该文件内容会消失。若文件不存在则建立该文件。
# (4)w+ 打开可读写文件,若文件存在则文件长度清为零,
# 即该文件内容会消失。若文件不存在则建立该文件。
# (5)a 以附加的方式打开只写文件。若文件不存在,
# 则会建立该文件,如果文件存在,写入的数据会被加到文件尾,
# 即文件原先的内容会被保留。
# (6) a+ 以附加方式打开可读写的文件。
# 若文件不存在,则会建立该文件,
# 如果文件存在,写入的数据会被加到文件尾后,
# 即文件原先的内容会被保留。



加油一起学习,更新完毕

猜你喜欢

转载自blog.csdn.net/qq_33094993/article/details/78994456
今日推荐