博客
关于我
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/

你可能感兴趣的文章
Navicate for mysql 数据库设计-数据库分析
查看>>
Navicat下载和破解以及使用
查看>>
Navicat中怎样将SQLServer的表复制到MySql中
查看>>
navicat创建连接 2002-can‘t connect to server on localhost(10061)且mysql服务已启动问题
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Navicat向sqlserver中插入数据时提示:当 IDENTITY_INSERT 设置为 OFF 时,不能向表中的标识列插入显式值
查看>>
Navicat因导入的sql文件中时间数据类型有参数而报错的原因(例:datetime(3))
查看>>
Navicat如何连接MySQL
查看>>
navicat导入.sql文件出错2006- MySQLserver has gone away
查看>>
Navicat工具Oracle数据库复制 or 备用、恢复功能(评论都在谈论需要教)
查看>>
navicat怎么导出和导入数据表
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
nc命令详解
查看>>
ndk特定版本下载
查看>>
NDK编译错误expected specifier-qualifier-list before...
查看>>
Neat Stuff to Do in List Controls Using Custom Draw
查看>>
Necurs僵尸网络攻击美国金融机构 利用Trickbot银行木马窃取账户信息和欺诈
查看>>