关于格式转换

关于格式

1.json

dict = json.loads(str)
str = json.dumps(dict)

2.pickle

pickle模块是python的标准模块,提供了对于python数据的序列化操作,可以将数据转换为bytes类型,其序列化速度比json模块要高。

  • pickle.dumps() 将python数据序列化为bytes类型

  • pickle.loads() 将bytes类型数据反序列化为python的数据类型

    import pickle

    d = {'1': {'count': 10, 'selected': True}, '2': {'count': 20, 'selected': False}}
    s = pickle.dumps(d)
    s
    b'x80x03}qx00(Xx01x00x00x001qx01}qx02(Xx05x00x00x00countqx03K Xx08x00x00x00selectedqx04x88uXx01x00x00x002qx05}qx06(hx03Kx14hx04x89uu.'
    pickle.loads(s)
    {'1': {'count': 10, 'selected': True}, '2': {'count': 20, 'selected': False}}

3.base64

python标准库中提供了base64模块,用来进行转换

  • base64.b64encode() 将bytes类型数据进行base64编码,返回编码后的bytes类型

  • base64.b64deocde() 将base64编码的bytes类型进行解码,返回解码后的bytes类型

    接pickle测试

    import base64
    s
    b'x80x03}qx00(Xx01x00x00x001qx01}qx02(Xx05x00x00x00countqx03K Xx08x00x00x00selectedqx04x88uXx01x00x00x002qx05}qx06(hx03Kx14hx04x89uu.'
    b = base64.b64encode(s)
    b
    b'gAN9cQAoWAEAAAAxcQF9cQIoWAUAAABjb3VudHEDSwpYCAAAAHNlbGVjdGVkcQSIdVgBAAAAMnEFfXEGKGgDSxRoBIl1dS4='
    base64.b64decode(b)
    b'x80x03}qx00(Xx01x00x00x001qx01}qx02(Xx05x00x00x00countqx03K Xx08x00x00x00selectedqx04x88uXx01x00x00x002qx05}qx06(hx03Kx14hx04x89uu.'

    cart_str = request.COOKIES.get('cart') #从redis取出的时str格式

    解析

    cart_bytes = cart_str.encode() # str -> bytes
    cart_bytes2 = base64.b64decode(cart_str) # b64decode(byes类型)
    cart_dict = pickle.loads(cart_bytes)

4.只要是从redis往外取值,取出来的都是bytes格式. redis保存的键值对都是字符串格式.

5.cookie只能保存字符串格式

原文地址:https://www.cnblogs.com/bsth/p/10220373.html