博客
关于我
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性能优化(八)--
查看>>
MySQL性能测试及调优中的死锁处理方法
查看>>
mysql性能测试工具选择 mysql软件测试
查看>>
mysql恢复root密码
查看>>
Mysql悲观锁
查看>>
MySQL慢查询-开启慢查询
查看>>
MySQL慢查询分析和性能优化的方法和技巧
查看>>
MySQL慢查询日志总结
查看>>
Mysql慢查询日志,查询截取分析
查看>>
MySQL慢查询问题排查
查看>>
mysql截取sql语句
查看>>
mysql截取身份证号前几位_EXCEL中怎样截取身份证号前六位数字
查看>>
mysql手工注入
查看>>
MySQL执行SQL文件出现【Unknown collation ‘utf8mb4_0900_ai_ci‘】的解决方案
查看>>
Mysql执行update by id的过程
查看>>
mysql执行计划
查看>>
MySQL执行计划 EXPLAIN参数
查看>>
MySQL执行计划【explain】,看这一篇就够啦!
查看>>
Mysql执行计划字段解释
查看>>
mysql执行计划怎么看
查看>>