一、random 模块:随机数

1、part1

import random

1、[1,10]整数 random randint(1,10)
print(random.randint(1, 10)) # 随机产生[1,10]中的一个数 2、(0,1)小数 random.random()
print(random.random()) 3、[1,10)整数 random.randrange(1,10)
print(random.randrange(1, 10)) 4、(1,10)小数 random.uniform(1,10)
print(random.uniform(1,10)) print(random.choice([1,2,3])) # 单例集合随机选择1个
print(random.sample([1,2,3,4,5,6],2)) # 单例集合随机选择n个 5、洗牌random.shuffle
ls=[0,1,2,3,4,5,6]
random.shuffle(ls)
print(ls)

2、案例

产生指定位数的验证码

import random
def random_code(count):
code =''
for i in range(count):
num = random.randint(,)
if num == :
tag = str(random.randint(,))
elif num == :
tag = chr(random.randint(,))
else :
tag = chr(random.randint(,))
code += tag return code
print(random_code())

二、shutil 模块:可以操作权限的处理文件模块

import shutil

、基于路径的文件复制
shutil.copyfile(r'D:\SH-fullstack-s3\day18\part1\b.py','bb') 、基于流的文件复制
with open('c.py','rb') as r ,open('d.py','wb') as w:
shutil.copyfileobj(r,w) 、递归删除目标目录
shutil.rmtree('a') 、文件移动
shutil.move('d.py','dd.py') 文件夹压缩
shutil.make_archive('aaaa','zip',r'D:\SH-fullstack-s3\day18\part1') 、文件夹解压
shutil.unpack_archive(r'D:\SH-fullstack-s3\day18\part1\aaaa.zip','aaaaaa','zip')

三、shevle 模块:可以用字典存取数据到文件的序列化模块

import shelve

将序列化文件操作dump与load进行封装
s_dic = shelve.open("target.txt") # 注:writeback=True操作数据会同步写到文件

序列化::存
s_dic['key1'] = [, , , , ]
s_dic['key2'] = {'name': 'Bob', 'age': }
s_dic['key3'] = 'abc'

文件释放
s_dic.close() s_dic = shelve.open("target.txt", writeback=True)
print(s_dic['key1'])
s_dic['key1'][] =
print(s_dic['key1']) print(s_dic['key2'])
s_dic['key2']['age'] =
print(s_dic['key2']) print(s_dic['key3'])
s_dic['key3'] = 'def'
print(s_dic['key3'])
s_dic.close()

四、三流:系统标准输入流 | 输出流 | 错误流

import sys

、系统标准输入流
sys.stdout.write('') # print('msg',end='')
sys.stdout.write('') # == print()
结果为 sys.stdout.write('123\n')
sys.stdout.write('')
结果为
、系统标准输出流
res = sys.stdin.read()
print(res)
res = sys.stdin.readline()
print(res) 、系统标准错误流 sys.stderr.write('错误信息\n')
sys.stderr.write('错误信息')
sys.stderr.write('错误信息') 结果为
错误信息
错误信息错误信息

五、logging

1、logging模块是python提供的用于记录日志的模块

2、日志级别:五个级别,从高到低

info:常规信息  10

debug:调试信息  20

warning:警告信息  30

error:错误信息  40

cretical:严重错误  50

3、logging模块的四个核心角色

Logger:日志生长器,产生日志

Fitler:日志过滤器,过滤日志

Handler:日志处理器,对日志进行格式化,并输出到指定位置(控制台或文件)

Formater:处理日志的格式

4、通过字典配置日志模块(重点)

六、xlrd与xlwt

1、xlrd

read.xslx表格:

import xlrd
import xlwt
import os class ExcelRead(object):
def __init__(self, excel_name, sheet_name):
self.path = os.path.join(os.path.join(os.path.dirname(__file__), "upload"), excel_name)
self.data = xlrd.open_workbook(self.path) # 打开指定的excel文件
self.table = self.data.sheet_by_name(sheet_name) # 找到指定的sheet页
self.rows = self.table.nrows # 获取总行数
self.cols = self.table.ncols # 获取总列数 def data_dict(self):
if self.rows <=1:
print('总行数小于等于1', end='')
print(self.path)
return False
else:
keys = self.table.row_values(0) # 将列表的第一行设置为字典的key值
data = []
for i in range(1, self.rows):
dict = {}
for j in range(0, self.cols):
dict[keys[j]] = self.table.row_values(i)[j]
data.append(dict)
return data if __name__ == '__main__':
start = ExcelRead('xlrd.xlsx', u'read')
data = start.data_dict() for i in range(len(data)):
print(data[i])

结果为:

2、xlwt

excel_path = os.path.join(os.path.join(os.path.dirname(__file__), "upload"), 'xlwt.xlsx')

class ExcelWrite(object):
def __init__(self):
self.excel = xlwt.Workbook() # 创建一个工作簿
self.sheet = self.excel.add_sheet('Sheet4') # 创建一个工作表 # 写入单个值
def write_value(self, cell, value):
'''
- cell: 传入一个单元格坐标参数,例如:cell=(0,0),表示修改第一行第一列
'''
self.sheet.write(*cell, value)
# (覆盖写入)要先用remove(),移动到指定路径,不然第二次在同一个路径保存会报错
os.remove(excel_path)
self.excel.save(excel_path) # 写入多个值
def write_values(self, cells, values):
'''
- cells: 传入一个单元格坐标参数的list,
- values: 传入一个修改值的list,
例如:cells = [(0, 0), (0, 1)],values = ('a', 'b')
表示将列表第一行第一列和第一行第二列,分别修改为 a 和 b
'''
# 判断坐标参数和写入值的数量是否相等
if len(cells) == len(values):
for i in range(len(values)):
self.write_value(cells[i], values[i])
else:
print("传参错误,单元格:%i个,写入值:%i个" % (len(cells), len(values))) if __name__ == '__main__':
start = ExcelWrite()
cells1 = [(0, 0), (0, 1)]
values1 = ('飞猪', '哈哈')
start.write_values(cells1, values1)

结果为:

day18 十八、random、shutil、shevle、logging的更多相关文章

  1. 18 常用模块 random shutil shevle logging sys.stdin/out/err

    random:随机数 (0, 1) 小数:random.random() ***[1, 10] 整数:random.randint(1, 10) *****[1, 10) 整数:random.rand ...

  2. random shutil shevle xml

    random 模块 import random print(random.random())#(0,1)----float 大于0且小于1之间的小数 print(random.randint(1,3) ...

  3. Python之路(第十八篇)shutil 模块、zipfile模块、configparser模块

    一.shutil 模块 1.shutil.copyfileobj(fsrc, fdst[, length]) 将文件内容拷贝到另一个文件中,需要打开文件 import shutil shutil.co ...

  4. python 基础(十八)--shutil模块

    shutil模块 shutil.copyfileobj(src,dst):只拷贝文件内容,需要open文件:目标文件不存在时创建,存在时覆盖 shutil.copyfileobj(open('old. ...

  5. 十八. Python基础(18)常用模块

    十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...

  6. 201771010126 王燕《面向对象程序设计(java)》第十八周学习总结

    实验十八  总复习 实验时间 2018-12-30 1.实验目的与要求 (1) 综合掌握java基本程序结构: (2) 综合掌握java面向对象程序设计特点: (3) 综合掌握java GUI 程序设 ...

  7. 马昕璐 201771010118《面向对象程序设计(java)》第十八周学习总结

    实验十八  总复习 实验时间 2018-12-30 1.实验目的与要求 (1) 综合掌握java基本程序结构: (2) 综合掌握java面向对象程序设计特点: (3) 综合掌握java GUI 程序设 ...

  8. 刘志梅 201771010115 《面向对象程序设计(java)》 第十八周学习总结

    实验十八 总复习 实验时间 2018-12-30 1.实验理论知识 (1)第一个关键词:public称为访问修饰符,用于控制程序的其他部分对代码的访问级别. 第二个关键词:class表明java程序中 ...

  9. 了解Kubernetes主体架构(二十八)

    前言 Kubernetes的教程一直在编写,目前已经初步完成了以下内容: 1)基础理论 2)使用Minikube部署本地Kubernetes集群 3)使用Kubeadm创建集群 接下来还会逐步完善本教 ...

随机推荐

  1. 关于ProgressDialog.show抛出android.view.WindowManager$BadTokenException: Unable to add window

    下午摆弄ProgressDialog,进入就抛错:android.view.WindowManager$BadTokenException: Unable to add window -- token ...

  2. nrm管理npm源

    npm源:npm install命令下载需要依赖包的服务器地址,默认是 npm ---- https://registry.npmjs.org/ 而国外的源速度太慢,所以我们一般都用国内的淘宝源tao ...

  3. Python的虚拟机安装已经如何配置Scrapy for Mac

    时间:2018年2月21日 因为时间问题,以下笔记就粗略记录.仅作为个人笔记为用 安装virtualenv和virtualenvwrapper 如何安装的细节下面这篇也有介绍,包括如何使用切换虚拟机也 ...

  4. Effective Java 第三版——80. EXECUTORS, TASKS, STREAMS 优于线程

    Tips 书中的源代码地址:https://github.com/jbloch/effective-java-3e-source-code 注意,书中的有些代码里方法是基于Java 9 API中的,所 ...

  5. MySql 建表、添加字段、修改字段、添加索引SQL语句写法及SQL索引

    ---------添加索引方法--------- .添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `c ...

  6. Atitit 乌合之众读后感attilax总结 与读后感结构规范总结

    Atitit 乌合之众读后感attilax总结 与读后感结构规范总结 1. 背景概览与鸟瞰overview 1 1.1. 社会背景 与 历史事件背景  与历史时间背景 1 1.2. 书籍简绍 2 1. ...

  7. mybatis generator生成文件大小写问题

    mybatis generator插件中,如果 mysql数据表中的字段是用下划线划分的(个人一般都是喜欢这么创建表的字段,如:company_name),那么生成的Vo中会自动对应为companyN ...

  8. [转]用JAVA在读取EXCEL文件时如何判断列隐藏

    原文地址:https://www.cnblogs.com/OwenWu/archive/2012/01/03/2310620.html org.apache.poi.hssf.usermodel.HS ...

  9. 使用nginx搭建rtmp服务器

    一.软件需求 1.nginx源码包  下载地址:http://nginx.org/.笔者下载的是1.10.3. 2.pcre源码包.这是一个正则表达式库.nginx会用到这个开源库来做正则匹配.很多软 ...

  10. js命名空间的函数namespace

    这是一个扩展函数,需要初期加载的时候加载到适当的位置. 具体函数体如下: $.namespace = function() { var a=arguments, o=null, i, j, d; fo ...