StringIO BytesIO

>>>from io import StringIO
>>>f = StringIO()
>>>f.write('something')
>>>print(f.getvalue())  #这里无法使用read(),请看读取

读取

>>>from io import StringIO
>>>f = StringIO('something')
>>>while True:
>>>    s = f.readline()  #--我是读取--这里可以,主要差别在于初始化时是否传入参数(StringIO()中是否有传入)
>>>    if s == '':
>>>        break
>>>    print(s.strip())

BytesIO与StringIO类似

>>> from io import BytesIO
>>> f = BytesIO()
>>> f.write('中文'.encode('utf-8')) #把‘中文’以utf-8的方式编码
6
>>> print(f.getvalue())
b'\xe4\xb8\xad\xe6\x96\x87'
>>> from io import BytesIO
>>> f = BytesIO(b'\xe4\xb8\xad\xe6\x96\x87')
>>> f.read()
b'\xe4\xb8\xad\xe6\x96\x87'
 
转载至廖老师教程下的评论点击打开链接

# StringIO和BytesIO

# stringIO 比如说,这时候,你需要对获取到的数据进行操作,但是你并不想把数据写到本地硬盘上,这时候你就可以用stringIO
from io import StringIO
from io import BytesIO
def outputstring():
    return 'string \nfrom \noutputstring \nfunction'

s = outputstring()

# 将函数返回的数据在内存中读
sio = StringIO(s)
# 可以用StringIO本身的方法
print(sio.getvalue())
# 也可以用file-like object的方法
s = sio.readlines()
for i in s:
    print(i.strip())


# 将函数返回的数据在内存中写
sio = StringIO()
sio.write(s)
# 可以用StringIO本身的方法查看
s=sio.getvalue()
print(s)

# 如果你用file-like object的方法查看的时候,你会发现数据为空

sio = StringIO()
sio.write(s)
for i in sio.readlines():
    print(i.strip())

# 这时候我们需要修改下文件的指针位置
# 我们发现可以打印出内容了
sio = StringIO()
sio.write(s)
sio.seek(0,0)
print(sio.tell())
for i in sio.readlines():
    print(i.strip())

# 这就涉及到了两个方法seek 和 tell
# tell 方法获取当前文件读取指针的位置
# seek 方法,用于移动文件读写指针到指定位置,有两个参数,第一个offset: 偏移量,需要向前或向后的字节数,正为向后,负为向前;
#第二个whence: 可选值,默认为0,表示文件开头,1表示相对于当前的位置,2表示文件末尾
# 用seek方法时,需注意,如果你打开的文件没有用'b'的方式打开,则offset无法使用负值哦



# stringIO 只能操作str,如果要操作二进制数据,就需要用到BytesIO
# 上面的sio无法用seek从当前位置向前移动,这时候,我们用'b'的方式写入数据,就可以向前移动了
bio = BytesIO()
bio.write('s'.encode('utf-8'))
print(bio.getvalue())
bio.seek(-36,1)
print(bio.tell())
for i in bio.readlines():
    print(i.strip())


其实层主这里之所以文件的指针位置需要修改,是因为涉及到一个没有被提及的小知识点:

当使用StringIO()去初始化的时候,其指针是指向0的位置;而如果是用write的方法的时候,其指针则是会移动到后面的。

举例如下:

            >>>sio = StringIO('abc')

            >>>sio.getvalue()

            'abc'

            >>>sio = StringIO('def')

            >>>sio.getvalue()

            'def'

上面这里显示使用StringIO()进行初始化,是覆盖原值的,指针始终是指向0的位置。

对比write的方法:

            >>>a = StringIO()

            >>>a.write('123')

            3

            >>>a.getvalue()

            '123'

            >>>a.write('456')

            3

            >>>a.getvalue()

            '123456'

可以看出,write的方法本质上是追加。

再举例如下:

            >>>sio = StringIO('abc') #这里是初始化,指针指向0

            >>>sio.getvalue()

            'abc'

            >>>sio = StringIO('def') #这里是再次初始化,指针仍然指向0

            >>sio.getvalue()

            'def'

            #def覆盖原值abc

            >>sio.write('ghi')

            #这里要注意了,虽然是追加,但是由于指针仍然是0,所以实际上仍然会覆盖掉原值3

            >>>sio.getvalue()

            'ghi'

            >>>sio.write('ghi') #上面第一次追加以后,指针就向后移动,所以此处才真正起到追加的效果3

            >>>sio.getvalue()

            'ghighi'





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值