#17 random&json模块
前言
本节将讲解两个模块,一个是随机模块random,一个是字符串和字典之间的转换模块json,这两个模块使用率还是很高的,来认识一下!
一、random模块
random的官方文档:https://docs.python.org/3.5/library/random.html
这里只记录常用的方法:
In [3]: import random # 导入random模块 In [4]: random.random() # 随机生成0到1之间的浮点数,注意:包括0和1
Out[4]: 0.8952565343053827 In [5]: random.random() # 再生成一个
Out[5]: 0.6822327896680234
In [12]: import random In [13]: random.randint(1,10) # 随机生成一个1到10之间的整数,包括1和10
Out[13]: 5 In [14]: random.randint(1,10) # 再生成一个
Out[14]: 2
In [15]: import random In [17]: random.uniform(1.1,9.9) # 随机生成一个1.1到9.9之间的浮点数,区间可以是浮点数
Out[17]: 8.136851906531758 In [18]: random.uniform(1.1,9.9) # 再生成一个
Out[18]: 8.24769737404256
In [19]: import random
In [20]: random.choice('I am MinuteSheep') # 随机从字符串里面取出一个字符
Out[20]: 'u'
In [22]: random.choice('I am MinuteSheep') # 再取一个
Out[22]: 'I'
In [25]: random.choice('I am MinuteSheep') # 空格也算一个字符哦
Out[25]: ' '
In [26]: random.choice([1,2,4,6,9]) # 列表也行,字典不行
Out[26]: 2
In [28]: import random In [29]: random.randrange(1,15) # 随机生成一个1到15的整数,和randint()相同
Out[29]: 12 In [32]: random.randrange(1,15,2) # 随机生成一个1到15且间距为2的整数,相当于从[1,3,5,7,9,11,13,15]里面随机取出一个
Out[32]: 11 In [33]: random.randrange(1,15,2)
Out[33]: 3 In [34]: random.randrange(1,15,2)
Out[34]: 9 In [35]: random.randrange(1,15,2)
Out[35]: 1
In [39]: import random In [40]: num = [1,2,3,4,5,6,7] In [41]: random.shuffle(num) # 将列表里面的元素随机打乱 In [42]: num
Out[42]: [3, 7, 5, 1, 2, 6, 4] In [43]: random.shuffle(num) # 再打乱一次 In [44]: num
Out[44]: [1, 6, 4, 3, 5, 2, 7]
二、json模块
json官方文档:https://docs.python.org/3.5/library/json.html
大家可能知道一些常见的文件格式,比如:txt、pdf、exe、word、ppt、excel
、zip等等,在程序员这里,通常数据保存为json格式,尤其是作前端的程序员,json实质上是类似字典的字符串,比如:
'{"name":"MinuteSheep", "age":100, "gender": "male"}'
乍一看,是个字典;再一看,是个字符串!
如果想要提取出这段字符串的‘name’信息,想要对其进行字典的操作显然是不可能的,这时候就要用到json模块了:
In [60]: import json # 导入json模块
In [61]: info = '{"name":"MinuteSheep", "age":100, "gender": "male"}' # 这是一个字符串
In [62]: type(info) # 查看其类型,确认是字符串
Out[62]: str
In [63]: info_dict = json.loads(info) # 使用json.loads(str)将其转换为字典
In [64]: info_dict # 可以看到这是一个字典
Out[64]: {'age': 100, 'gender': 'male', 'name': 'MinuteSheep'}
In [65]: info_dict['name'] # 可以对其进行字典的操作
Out[65]: 'MinuteSheep'
# 特别注意:只适用于'{"key":"value"}'的字符串,不适用于"{'key':'value'}"的字符串
同样,对于字典,也可以将其转换为字符串形式:
In [68]: import json
In [69]: info = {'age': 100, 'gender': 'male', 'name': 'MinuteSheep'} # 初始化一个字典用作示例
In [70]: type(info) # 确认这是个字典
Out[70]: dict
In [71]: json.dumps(info) # 使用json.dumps(dict)将其转换为字符串
Out[71]: '{"age": 100, "gender": "male", "name": "MinuteSheep"}'
# 注意:这个方法适用于{"key":"value"}、{'key':'value'}、{'key':"value"}、{"key":'value'}的字典
json最常用的方法就是这两个,还有两个用的不多的方法:json.load(),json.dump(),这两个用于写入文件,具体使用请查看官方文档
#17 random&json模块的更多相关文章
- python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib subprocess logging re正则
python 常用模块 time random os模块 sys模块 json & pickle shelve模块 xml模块 configparser hashlib subprocess ...
- Python(正则 Time datatime os sys random json pickle模块)
正则表达式: import re #导入模块名 p = re.compile(-]代表匹配0至9的任意一个数字, 所以这里的意思是对传进来的字符串进行匹配,如果这个字符串的开头第一个字符是数字,就代表 ...
- Python 自学基础(四)——time模块,random模块,sys模块,os模块,loggin模块,json模块,hashlib模块,configparser模块,pickle模块,正则
时间模块 import time print(time.time()) # 当前时间戳 # time.sleep(1) # 时间延迟1秒 print(time.clock()) # CPU执行时间 p ...
- python学习笔记(四)random 、json模块
一.模块简介 Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 导入模块 import module #导入模块 f ...
- 模块之 time datetime random json pickle os sys hashlib collections
目录 1. time模块 1.1表示时间的几种方式: 1.2格式化字符串的时间格式 1.3不同格式时间的转换 2.datetim模块 3.random模块 4. json模块 4.1dumps.loa ...
- python基础四(json\os\sys\random\string模块、文件、函数)
一.文件的修改 文件修改的两种思路: 1.把文件内容拿出来,做修改后,清空原来文件的内容,然后把修改过的文件内容重新写进去. 步骤: 1.打开文件:f=open('file','a+') #必须用a ...
- 全局变量 urllib模块 json模块
1.vars() 查看一个.py文件中的全局变量 print(vars()) #重点 __name__': '__main__ '__file__': 'C:/Users/lenovo/Pychar ...
- Python 第三篇(上):python文件基础操作、json模块、lambda、map、filter、reduce和函数位置参数
python一切皆对象,linux一切皆文件,python操作文件是很常见的O/I操作,其内置来open()函数可以完成文件的基本操作: 一:使用内置open()函数操作文件,基本语法如下: with ...
- 函数和常用模块【day06】:json模块(十一)
本节内容 1.dumps序列化和loads反序列化 2.dump序列化和load反序列化 3.序列函数 1.dumps序列化和loads反序列化 dumps()序列化 1 2 3 4 5 6 7 8 ...
随机推荐
- 【APP测试(Android)】--交叉事件
- pycharm 2017最新激活码
BIG3CLIK6F-eyJsaWNlbnNlSWQiOiJCSUczQ0xJSzZGIiwibGljZW5zZWVOYW1lIjoibGFuIHl1IiwiYXNzaWduZWVOYW1lIjoiI ...
- jdk8中关于操作集合的一些新特性,遍历和排序操作
jdk8增加了不少新的东西,在集合操作这块,就有如 lamda表达式,stream,sort,optional等新的类,主要涉及遍历和排序等方面,新特性提升了不少性能,我们开发就是要拥抱新事物,守着老 ...
- 用VerilogHDL设计一个与门逻辑,并进行前仿和后仿
执行菜单命令[File]-[New Project Wizard…],创建工程向导. 在What is the working directory for this project?下选择项目存储地址 ...
- linux、centos下安装配置vim
---恢复内容开始--- 1.一般情况下安装上centos后,会有vi,没有vim(以后可能会有吧) 如果不确定自己有没有vim,使用命令 rpm -qa|grep vim 查看,如果有的话,会显示三 ...
- 附加题2 :git 简单练习
目的: 练习git 基本操作 理解版本管理 Task 1:在码云上新建一个项目,项目命名 『Helloworld』 ,设置为公开访问. step 0: 在你计算机安装git.参照互联网教程<gi ...
- 【接口时序】5、QSPI Flash的原理与QSPI时序的Verilog实现
一. 软件平台与硬件平台 软件平台: 1.操作系统:Windows-8.1 2.开发套件:ISE14.7 3.仿真工具:ModelSim-10.4-SE 4.Matlab版本:Matlab2014b/ ...
- MongoDB 字符串值长度条件查询
在实际项目中常常会有根据字段值长度大小进行限制查询,例如查询商品名称过长或过短的商品信息,具体的实现方式可能有多种,在此记录常见的两种实现 使用 $where 查询(性能稍逊一些) 1 2 3 4 5 ...
- 分布式任务调度系统xxl-job源码探究(二、服务中心)
接下来看下服务端代码 服务端源码 服务端通过管理quartz定时任务组件,分发任务 先从入口看起,由web.xml进入,可以看出,自己编写的代码从applicationcontext-xxl-job- ...
- 从零搭建java后台管理系统(二)mysql和redis安装
接上篇开始安装mysql和redis 注意了,如果用阿里云服务器,外网访问的端口必须在安全组开启,否则外网访问不通 三.服务器安装redis和mysql 本次环境搭建将所有第三方服务会安装在阿里云服务 ...