博客
关于我
StringIO和BytesIO
阅读量:494 次
发布时间:2019-03-07

本文共 1037 字,大约阅读时间需要 3 分钟。

概述

  数据读写不一定是文件,也可在内存中读写
  在内存中读写可分为两种:
    1) 读写字符(StringIO),其操作的是str
    2) 字节读写(BytesIO),其操作的二进制数据

StringIO

  StringIO就是在内存中读写str
  要把str写入StringIO,需先创建一个StringIO,然后像文件一样写入即可
  要读取StringIO,可以用一个str初始化StringIO,然后像读文件一样读取

  实例

from io import StringIO        f_w = StringIO()f_w.write('hello')f_w.write(' ')f_w.write('world!')print(f_w.getvalue())   #getvalue()方法用于获得写入后的str                        #output --> hello world!        f_r = StringIO('Hello!\nHi!\nGoodbye!')while True:  s = f_r.readline() #readline()方法从StringIO中读取str  if s == '':    break  print(s.strip())

BytesIO

  BytesIO就是在内存中读写bytes

  要把bytes写入BytesIO,需先创建一个BytesIO,然后像文件一样写入即可
  要读取BytesIO,可以用一个bytes初始化BytesIO,然后像读文件一样读取

  实例

from io import BytesIOf_w = BytesIO()f_w.write('中文'.encode('utf-8')) #写入的不是str,而是经过UTF-8编码的bytesprint(f_w.getvalue()) #getvalue()方法用于获得写入后的bytes                      #output --> b'\xe4\xb8\xad\xe6\x96\x87'                                     f_r = BytesIO(b'\xe4\xb8\xad\xe6\x96\x87')print(f_r.read()) #output --> b'\xe4\xb8\xad\xe6\x96\x87'

转载地址:http://ryicz.baihongyu.com/

你可能感兴趣的文章
MySQL高级-SQL优化步骤
查看>>
MySQL高级-内存管理及优化
查看>>
MySQL高级-存储过程和函数
查看>>
MySQL高级-索引
查看>>
MySQL高级-索引的使用及优化
查看>>
MySQL高级-视图
查看>>
MySQL高级-触发器
查看>>
Mysql高级——锁
查看>>
mysql高级查询~分页查询
查看>>
mysql高级查询之多条件的过滤查询
查看>>
MySQL高级配置
查看>>
MySQL高频面试题
查看>>
MySQL高频面试题的灵魂拷问
查看>>
MySQL(1)的使用 | SQL
查看>>
MySQL(2)DDL详解
查看>>
MySQL(3)DML详解
查看>>
MySQL(4)运算符 | 关联查询详解
查看>>
MySQL(5)条件查询 | 单行函数 | 事务详解
查看>>
Mysql,group by分组查询、order by排序查询、join连接查询、union联合查询
查看>>
Mysql,sql文件导入和导出
查看>>