前言

本节将讲解两个模块,一个是随机模块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模块的更多相关文章

  1. 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 ...

  2. Python(正则 Time datatime os sys random json pickle模块)

    正则表达式: import re #导入模块名 p = re.compile(-]代表匹配0至9的任意一个数字, 所以这里的意思是对传进来的字符串进行匹配,如果这个字符串的开头第一个字符是数字,就代表 ...

  3. Python 自学基础(四)——time模块,random模块,sys模块,os模块,loggin模块,json模块,hashlib模块,configparser模块,pickle模块,正则

    时间模块 import time print(time.time()) # 当前时间戳 # time.sleep(1) # 时间延迟1秒 print(time.clock()) # CPU执行时间 p ...

  4. python学习笔记(四)random 、json模块

    一.模块简介 Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 导入模块 import module #导入模块 f ...

  5. 模块之 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 ...

  6. python基础四(json\os\sys\random\string模块、文件、函数)

    一.文件的修改 文件修改的两种思路: 1.把文件内容拿出来,做修改后,清空原来文件的内容,然后把修改过的文件内容重新写进去. 步骤: 1.打开文件:f=open('file','a+')  #必须用a ...

  7. 全局变量 urllib模块 json模块

    1.vars()  查看一个.py文件中的全局变量 print(vars()) #重点 __name__': '__main__ '__file__': 'C:/Users/lenovo/Pychar ...

  8. Python 第三篇(上):python文件基础操作、json模块、lambda、map、filter、reduce和函数位置参数

    python一切皆对象,linux一切皆文件,python操作文件是很常见的O/I操作,其内置来open()函数可以完成文件的基本操作: 一:使用内置open()函数操作文件,基本语法如下: with ...

  9. 函数和常用模块【day06】:json模块(十一)

    本节内容 1.dumps序列化和loads反序列化 2.dump序列化和load反序列化 3.序列函数 1.dumps序列化和loads反序列化 dumps()序列化 1 2 3 4 5 6 7 8 ...

随机推荐

  1. Apache Beam编程指南

    术语 Apache Beam:谷歌开源的统一批处理和流处理的编程模型和SDK. Beam: Apache Beam开源工程的简写 Beam SDK: Beam开发工具包 **Beam Java SDK ...

  2. 简易数据库实现 UNIX环境高级编程(APUE)第二十章 A Database Library

    将课程的源代码 使用C++写了一部分 LINUX WINDOW均可运行 #ifndef MYDB_H #define MYDB_H #include <iostream> #include ...

  3. 2019.02.21 bzoj2739: 最远点(决策单调性+分治)

    传送门 题意简述:给一个N个点的凸多边形,求离每一个点最远的点. 思路:先根据初中数学知识证明决策是满足单调性的,然后上分治优化即可. 才不是因为博主懒得写二分+栈优化呢 代码: #include&l ...

  4. Postgresql之VACUUM和VACUUM FULL对比

    VACUUM命令存在两种形式,VACUUM和VACUUM FULL,它们之间的区别见如下表格: 无VACUUM VACUUM VACUUM FULL 删除大量数据之后 只是将删除数据的状态置为已删除, ...

  5. django.template.exceptions.TemplateDoesNotExist: login.html 错误处理

    登陆Login界面时候报错 Internal Server Error: /login/ Traceback (most recent call last): File , in inner resp ...

  6. azkaban disable 停用部分工作流

    在使用azkaban作为调度工具的时候,难免遇到只需要跑工作流某部分的情况,这时需要用到停用部分工作的操作, 如图:

  7. Apollo配置管理系统使用

  8. git diff 理解

    0. 理解 git diff 返回信息 1. 命令 $ git diff README.md 2. 返回信息,注解 diff --git a/README.md b/README.md ## 1. 表 ...

  9. Transport Layer Protocols

    1 End-to-end Protocols(端到端协议) 传输层协议往往是主机对主机(host-to-host)或者说是端到端(end-to-end).通常希望传输层协议可以提供如下service: ...

  10. Elastic-search在linux上的安装

    今天是我装第四次 ES ,之前装好用了一段时间,后面莫名其妙爆炸了,炸出一堆异常... 安装环境: JDK1.8   centos    ElasticSearch-6.2.4 jdk1.8以上,所以 ...