处理json
一、json
json是一个字符串,只不过长得比较像字典。使用json函数需要导入json库,即import json
json的格式只有双引号,不可用单引号
1、json.loads()和json.load()的区别
(1)json.loads() 将json串(字符串)转成字典
import json user_info = '''{"nhy":"123456","aa":"123456"}'''
print(user_info)
# {"nhy":"123456","aa":"123456"}
user_dic = json.loads(user_info)# 把json串(字符串)转成字典
print(user_dic)
# {'nhy': '123456', 'aa': '123456'}
print('user_dic',type(user_dic))
# user_dic <class 'dict'>
print('user_info',type(user_info))
# user_info <class 'str'>
(2) json.load(f) 这个是直接从文件里拿,不需要再读一次文件了,json直接读
注释:f是指文件
import json f = open('stu.json')
# stu.json文件内的内容
# {
# "laowang": {
# "cars": [
# "BMW",
# "Ben-z"
# ]
# }
# }
# res1 = json.loads(f.read())
# print(res1) #{'laowang': {'cars': ['BMW', 'Ben-z']}}
res = json.load(f)
print(res)
#{'laowang': {'cars': ['BMW', 'Ben-z']}}
2、json.dumps()和json.dump() 的区别
(1)json.dumps() 把字典转成json
import json stu_info = {'laowang':{'cars':['BMW','Ben-z']}}
# stu_info是字典
stu_str = json.dumps(stu_info)# 把字典转成json(字符串)
print('json...',type(stu_str))
# json... <class 'str'>
print(stu_str)
# {"laowang": {"cars": ["BMW", "Ben-z"]}}
(2)json.dump() 不需要自己再操作一遍write,会主动写入文件
import json stu_info = {'laowang':{'cars':['BMW','Ben-z']}}
# fw = open('stu.txt','w',encoding='utf-8')
# fw.write(stu_str) # stu_str是上述介绍json.dumps()中得到的json
# fw.close() fw = open('stu.json','w',encoding='utf-8')
json.dump(stu_info,fw,indent=4)# 不需要自己再write,会主动写入文件,indent指的是写入文件后,缩进几个空格
二、json写注册登录
import json
f = open('users.txt','a+',encoding='utf-8') #文件句柄,文件对象
f.seek(0)
all_users = json.load(f)
for i in range(3):
u = input('user:').strip()
p = input('p:').strip()
cp = input('cp:').strip()
if not u or not p:
print('账号、密码不能为空')
elif u in all_users:
print('该用户已经被注册!')
elif u not in all_users and cp==p:
all_users[u]=p
break
f.seek(0)
f.truncate()
json.dump(all_users,f,indent=4)
f.close() # username = input('username:')
# pwd = input('paswd')
#all_user = ['nhy','abc']
#passwd = ['123456','12345']
#
# if username in all_user and pwd in passwd:
# print('登录成功')
处理json的更多相关文章
- 使用TSQL查询和更新 JSON 数据
JSON是一个非常流行的,用于数据交换的文本数据(textual data)格式,主要用于Web和移动应用程序中.JSON 使用“键/值对”(Key:Value pair)存储数据,能够表示嵌套键值对 ...
- 【疯狂造轮子-iOS】JSON转Model系列之二
[疯狂造轮子-iOS]JSON转Model系列之二 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇<[疯狂造轮子-iOS]JSON转Model系列之一> ...
- 【疯狂造轮子-iOS】JSON转Model系列之一
[疯狂造轮子-iOS]JSON转Model系列之一 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 之前一直看别人的源码,虽然对自己提升比较大,但毕竟不是自己写的,很容易遗 ...
- Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)
背景: 1:有用户反馈了关于跨域请求的问题. 2:有用户反馈了参数获取的问题. 3:JsonHelper的增强. 在综合上面的条件下,有了2.2版本的更新,也因此写了此文. 开源地址: https:/ ...
- .NET Core系列 : 2 、project.json 这葫芦里卖的什么药
.NET Core系列 : 1..NET Core 环境搭建和命令行CLI入门 介绍了.NET Core环境,本文介绍.NET Core中最重要的一个配置文件project.json的相关内容.我们可 ...
- 一个粗心的Bug,JSON格式不规范导致AJAX错误
一.事件回放 今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...
- JSON.parse()和JSON.stringify()
1.parse 用于从一个字符串中解析出json 对象.例如 var str='{"name":"cpf","age":"23&q ...
- json与JavaScript对象互换
1,json字符串转化为JavaScript对象: 方法:JSON.parse(string) eg:var account = '{"name":"jaytan&quo ...
- .NET平台开源项目速览(18)C#平台JSON实体类生成器JSON C# Class Generator
去年,我在一篇文章用原始方法解析复杂字符串,json一定要用JsonMapper么?中介绍了简单的JSON解析的问题,那种方法在当时的环境是非常方便的,因为不需要生成实体类,结构很容易解析.但随着业务 ...
- WebApi接口 - 响应输出xml和json
格式化数据这东西,主要看需要的运用场景,今天和大家分享的是webapi格式化数据,这里面的例子主要是输出json和xml的格式数据,测试用例很接近实际常用情况:希望大家喜欢,也希望各位多多扫码支持和点 ...
随机推荐
- MIS系统部署方案
- C++数组与指针回顾总结
//数组名是常量指针, //a+1 是相对数组起始地址偏移了sizeof(int)字节 //&a+1 是相对于数组起始地址偏移了sizeof(a)字节 , , , }; cout <&l ...
- CRM客户关系管理系统知识点总结
一.项目需求(使用PrecessOn) 二.models.py from django.db import models from django.contrib.auth.models import ...
- codeforce453DIV2——D. GCD of Polynomials
题意 给出n(1–150). 输出两个多项式A,B从常数到最高次的系数,使得对两个多项式求gcd时,恰好经过n步得到结果. 多项式的gcd一步是指(A(x),B(x))变成(B,A mod B)的过程 ...
- jquery触发两次onchange事件
在项目中需要给select绑定改变事件,来触发动作,但是发现改变一次select,onchange方法执行两遍 //这是那个标签,用的是我们公司内部的selectlist <select cla ...
- 把List<string>转为DataTable
//把List<string>转为DataTable List<string> myList = new List<string>(); DataTable dt2 ...
- HandleErrorAttribute
前言 一直在给Team的人强调“Good programming is good Error Handling”,没人喜欢YSOD(Yellow Screen of Death).我每次看到黄页的时候 ...
- 13-STL-二分查找
STL中提供-二分查找算法(binary_search lower_bound upper_bound equal_range STL包含四种不同的二分查找算法,binary_search ...
- 33.HAVING 子句
HAVING 子句 在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使用. SQL HAVING 语法 SELECT column_name, aggregate_f ...
- ios7适配--uitableviewcell选中效果
ios7 UITableViewCell selectionStyle won't go back to blue up vote6down votefavorite 2 Xcode 5.0, iOS ...