- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python Json模块中dumps、loads、dump、load函数介绍由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
json模块dumps、loads、dump、load函数介绍 。
1、json.dumps() 。
json.dumps()用于将dict类型的数据转成str,因为如果直接将dict类型的数据写入json文件中会发生报错,因此在将数据写入时需要用到该函数.
1
2
3
4
5
6
7
8
9
10
|
import
json
name_emb
=
{
'a'
:
'1111'
,
'b'
:
'2222'
,
'c'
:
'3333'
,
'd'
:
'4444'
}
jsobj
=
json.dumps(name_emb)
print
(name_emb)
print
(jsobj)
print
(
type
(name_emb))
print
(
type
(jsobj))
|
运行结果如下:
{'a': '1111', 'c': '3333', 'b': '2222', 'd': '4444'} {"a": "1111", "c": "3333", "b": "2222", "d": "4444"} <type 'dict'> <type 'str'> 。
若在数据写入json文件时,未先进行转换,报错如下 。
1
2
3
4
5
6
7
8
9
10
|
import
json
name_emb
=
{
'a'
:
'1111'
,
'b'
:
'2222'
,
'c'
:
'3333'
,
'd'
:
'4444'
}
emb_filename
=
(
'/home/cqh/facedata/emb_json.json'
)
# jsobj = json.dumps(name_emb)
with
open
(emb_filename,
"w"
) as f:
f.write(name_emb)
f.close()
|
转换后再写入,则不报错 。
2、json.loads() 。
json.loads()用于将str类型的数据转成dict.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
import
json
name_emb
=
{
'a'
:
'1111'
,
'b'
:
'2222'
,
'c'
:
'3333'
,
'd'
:
'4444'
}
jsdumps
=
json.dumps(name_emb)
jsloads
=
json.loads(jsdumps)
print
(name_emb)
print
(jsdumps)
print
(jsloads)
print
(
type
(name_emb))
print
(
type
(jsdumps))
print
(
type
(jsloads))
|
运行结果如下:
'a'变成了u'a'是因为发生了类型转换,str会转换成unicode 。
{'a': '1111', 'c': '3333', 'b': '2222', 'd': '4444'} {"a": "1111", "c": "3333", "b": "2222", "d": "4444"} {u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'} <type 'dict'> <type 'str'> <type 'dict'> 。
3、json.dump() 。
json.dump()用于将dict类型的数据转成str,并写入到json文件中。下面两种方法都可以将数据写入json文件 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
import
json
name_emb
=
{
'a'
:
'1111'
,
'b'
:
'2222'
,
'c'
:
'3333'
,
'd'
:
'4444'
}
emb_filename
=
(
'/home/cqh/facedata/emb_json.json'
)
# solution 1
jsobj
=
json.dumps(name_emb)
with
open
(emb_filename,
"w"
) as f:
f.write(jsobj)
f.close()
# solution 2
json.dump(name_emb,
open
(emb_filename,
"w"
))
|
运行结果如下:
4、json.load() 。
json.load()用于从json文件中读取数据.
1
2
3
4
5
6
7
8
9
10
11
|
import
json
emb_filename
=
(
'/home/cqh/facedata/emb_json.json'
)
jsobj
=
json.load(
open
(emb_filename))
print
(jsobj)
print
(
type
(jsobj))
for
key
in
jsobj.keys():
print
(
'key: %s value: %s'
%
(key,jsobj.get(key)))
|
运行结果如下:
{u'a': u'1111', u'c': u'3333', u'b': u'2222', u'd': u'4444'} <type 'dict'> key: a value: 1111 key: c value: 3333 key: b value: 2222 key: d value: 4444 。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.
原文链接:https://blog.csdn.net/mr_evanchen/article/details/77879967 。
最后此篇关于Python Json模块中dumps、loads、dump、load函数介绍的文章就讲到这里了,如果你想了解更多关于Python Json模块中dumps、loads、dump、load函数介绍的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我正在研究 MySQL 用户定义函数 (UDF),它基本上是 Windows 系统函数的包装器。我的问题是 UDF 对于某些输入按预期工作,但会导致 mysqld 对于其他输入崩溃。 UDF 本身采用
我在 this 中搜索过官方文档查找python中 json.dump() 和 json.dumps() 之间的区别。很明显,它们与文件写入选项有关。 但是它们之间的详细区别是什么?在什么情况下一个比
以前写的很简单,只有几句话,最近发现本文是本博客阅读量最大的一篇文章,觉得这样有种把人骗进来的感觉,于是又细化了一些。如果还有不好的地方,欢迎指出。 首先说明基本功能: dumps是将dict转
有没有办法在运行 'erl' 时禁用“崩溃转储”和“核心转储”文件的生成? PS:我知道 erl 的“+d”选项,但我想完全禁用崩溃/核心转储的生成。 最佳答案 您还可以将 ERL_CRASH_DUM
这是一个错误吗? >>> import json >>> import cPickle >>> json.dumps(cPickle.dumps(u'å')) Traceback (most rece
我已经开始了解用于对象序列化和反序列化的pickle模块了。 我知道pickle.dump是用来将代码存储为字节流(序列化),而pickle.load本质上是相反的,转成流字节返回到 python 对
我有一个这种格式的字符串, d = {'details': {'hawk_branch': {'tandem': ['4210bnd72']}, 'uclif_branch': {'tandem':
下面是我的python代码 r = requests.get("https://www.googleapis.com/youtube/v3/search?part=snippet&maxResults
我正在使用 PigLatin,使用 grunt,每次我“转储”东西时,我的控制台都会被诸如此类、诸如此类的非信息所破坏,有没有办法抑制这一切? grunt> A = LOAD 'testingData
我正在尝试将 mongodump 编辑的一组 .bson 文件 mongorestore 到位于 docker 中的 mongo 数据库,在我只有 SSH 访问权限的 Ubuntu 实例上。 我有一个
我正在尝试使用语音发送文本 watson api,但是当我设置 interim_results = True 时,我收到了值错误。请帮助我:) with open(join(dirname(__fil
鉴于 dump.rdb(或 .json 格式)文件中现有 redis 数据库的快照,我想在我自己的机器上恢复此数据以在其上运行一些测试。 任何有关如何执行此操作的指示都将不胜感激。 我尝试解析 dum
我对 Laravel 4 和 Composer 还是很陌生。当我做 Laravel 4 教程时,我无法理解这两个命令之间的区别; php artisan dump-autoload 和 compose
之间有区别吗 object = {1:"one", 2:"two", 3:"three"} file.write(json.dumps(object)) 和 json.dump(object) .如果
导出/导入整个模式的旧方法: exp user/pwdp@server FILE=export.dmp OWNER=user ROWS=Y imp newuser/pwd@server FULL=
我有一堆需要恢复的 mongo 数据库。我使用 mongodump 获取备份目录,其中包括其中的集合。像这样: |- mydir |-- db1 |--- collection1 |--- colle
尽管我在 root 下运行 dotnet-dump,并且进程在 root 下运行(请参阅下面的服务描述),但似乎我缺乏一些权限。 我还尝试了 home、var 和 tmp 中的其他目录:所有相同的消息
我正在尝试生成 LLVM IR 代码,作为 Kaleidoscope tutorial 的一部分我已成功完成在同一台机器上,使用这些相同的编译器标志。 我的代码在 clang++ 3.4 中编译没有错
我正在使用 eclipse 开发 Web 应用程序,当我尝试从 eclipse 中在服务器上运行我的应用程序时遇到了问题。 # # A fatal error has been detected by
给定一个任意的 picklable Python 数据结构data,是 with open('a', 'bw') as f: f.write(pickle.dumps(data)) 相当于 w
我是一名优秀的程序员,十分优秀!