我正在尝试将字典转换为字节,但是在将其转换为正确格式时遇到问题。
首先,我尝试使用自定义架构映射字典。架构定义如下-
class User:
def __init__(self, name=None, code=None):
self.name = name
self.code = code
class UserSchema:
name = fields.Str()
code = fields.Str()
@post_load
def create_userself, data):
return User(**data)
我的字典结构如下-
user_dict = {'name': 'dinesh', 'code': 'dr-01'}
我正在尝试使用以下代码将字典映射到用户架构
schema = UserSchema(partial=True)
user = schema.loads(user_dict).data
这样做时, schema.loads 期望输入为str,字节或字节数组。以下是我将字典转换为字节所遵循的步骤
import json
user_encode_data = json.dumps(user_dict).encode('utf-8')
print(user_encode_data)
输出:
b'{"name ": "dinesh", "code ": "dr-01"}
如果尝试使用架构进行映射,则无法获得所需的架构对象。但是,如果我具有下面给出的格式的输出,则可以获取正确的架构对象。
b'{\n "name": "dinesh",\n "code": "dr-01"}\n'
有什么建议可以将字典转换为字节吗?
最佳答案
您可以在indent
中使用json.dumps()
选项来获取\n
符号:
import json
user_dict = {'name': 'dinesh', 'code': 'dr-01'}
user_encode_data = json.dumps(user_dict, indent=2).encode('utf-8')
print(user_encode_data)
输出:
b'{\n "name": "dinesh",\n "code": "dr-01"\n}'