博客
关于我
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_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>