美文网首页机器学习
机器学习之python学习(十九)

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

作者: SundayCoder | 来源:发表于2018-01-07 14:00 被阅读0次

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

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

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

    只使用权限w写入的时候每一行会产生空行。

    解决方法: 使用权限wb写入的时候不会产生空行。

    你们也可以参考廖雪峰大神的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+ 以附加方式打开可读写的文件。
    # 若文件不存在,则会建立该文件,
    # 如果文件存在,写入的数据会被加到文件尾后,
    # 即文件原先的内容会被保留。
    
    
    
    
    

    加油一起学习,更新完毕

    相关文章

      网友评论

        本文标题:机器学习之python学习(十九)

        本文链接:https://www.haomeiwen.com/subject/rsipnxtx.html