zoukankan      html  css  js  c++  java
  • Python文件读写 很久以前写的 保存在QQ空间 以后的东西都写在博客园好了

    Python文件读写

    文件读写

    假设现行目录有个1.txt 内容是123

    F=open(“1.txt”.”r”)#open就是读写命令 r是读的意思  前面的是目录,因为是当前 不用写全路径

    f.read() 就是写出f的内容 结果就是123咯。

    最后一步是调用close()方法关闭文件。文件使用完毕后必须关闭,因为文件对象会占用操作系统的资源,并且操作系统同一时间能打开的文件数量也是有限的

    但是没有读取成功就会close失败。  所以Python有个with

    With open() as f:

     Print(f.read())

     

    这个和if不是有点神似吗。。。

    调用read()会一次性读取文件的全部内容,如果文件有10G,内存就爆了,所以,要保险起见,可以反复调用read(size)方法,每次最多读取size个字节的内容。另外,调用readline()可以每次读取一行内容,调用readlines()一次读取所有内容并按行返回list。因此,要根据需要决定怎么调用。

    前面讲的默认都是读取文本文件,并且是UTF-8编码的文本文件。要读取二进制文件,比如图片、视频等等,用'rb'模式打开文件即可:

    >>> f = open('/Users/michael/test.jpg', 'rb')

    >>> f.read()

    b'xffxd8xffxe1x00x18Exifx00x00...' # 十六进制表示的字节

    后面输出应该也会有相应的方法。

     

    默认的的读文件方式是utf-8 的。要是不是的话,就还要传入一个参数。

    open(“”,””,”encoding=”gbk”,errors=”ignore”)#j假设编码是gbk而且用忽略错误的方式读取

     

    ---------------写文件

    说了“r”和“rb”是读文件

    辣么“w”和“wb”是写文件

     

    而读进来出来是read

    辣么写进去是write

     

    其余的和读文件操作类似。

    ----------------小试一波

    最后附上:

     

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

    rb 以二进制格式打开一个文件用于只读。文件指针将会放在文件的开头。这是默认模式。

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

    rb+ 以二进制格式打开一个文件用于读写。文件指针将会放在文件的开头。

    w 打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

    wb 以二进制格式打开一个文件只用于写入。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

    w+ 打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

    wb+ 以二进制格式打开一个文件用于读写。如果该文件已存在则将其覆盖。如果该文件不存在,创建新文件。

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

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

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

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

     

  • 相关阅读:
    window下eclipse4.5+hadoop2.6.1开发环境配置
    sqoop1.4.6从mysql导入hdfshivehbase实例
    sqoop1.9.7安装和使用
    sqoop1.4.6导出oracle实例
    sqoop1.4.6配置安装
    java 操作hbase1.2
    hbase-1.2.5完全分布式部署
    hadoop2.6环境中部署hive1.2.2的错误
    hive 创建表和导入数据实例
    hive1.2.2部署
  • 原文地址:https://www.cnblogs.com/juemz/p/6360098.html
Copyright © 2011-2022 走看看