python MySQL入库json格式数据问题

python MySQL入库json格式数据问题

0x01 入库含有特殊字符的dict类型数据

escape_string

data = {'name': 'MR."H\'\\\'\\\n\t\rU"'}
# 上面data为dict类型数据,含有特殊字符
data = json.dumps(data)
# json.dumps加载成str类型,此时
data = pymysql.escape_string(data)
# 通过pymysql.escape_string将特殊字符进行转义
sql = "insert into test(`test`) values('%s')"%(data)
# 可以入库,入库时test字段类型为json

ast.literal_eval
通过ast.literal_eval将str类型转换为dict类型,除去dict中的特殊字符:

data = {'name': 'MR."H\'\\\'\\\n\t\rU"'}
data = str(data)
data = data.replace("\\'", "")
data = data.replace("\"", "")
data = data.replace("\\n", "")
data = data.replace("\\t", "")
data = data.replace("\\r", "")
data = data.replace("\\", "")

print(type(data))
print(data)
data = ast.literal_eval(data)
print(type(data))
print(data)
data = json.dumps(data)
print(type(data))
print(data)


<class 'str'>
{'name': 'MR.HU'}
<class 'dict'>
{'name': 'MR.HU'}
<class 'str'>
{"name": "MR.HU"}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值