python21day
内容回顾
re模块的常用方法
- findall(正则,待匹配字符串,flag):返回所有匹配项的列表
- search:返回一个变量,通过group取到第一个匹配项
- match:从头开始找第一个,其他同search
- finditer:返回一个迭代器,通过迭代再group取到一个变量
- compile(正则)同一个正则表达式要多次使用,提前编译节约时间
- split:通过正则表达式匹配的内容进行分割
- sub:替换,通过正则表达式匹配的内容进行替换
- subn:替换,在sub基础上返回一个元组,第一项内容是替换结果,第二项是替换次数
标签匹配+身份证号匹配例子
分组命名 取消分组优先
- (?P<组名>正则)(?P=组名)(?:正则)
# 匹配年月日日期 格式2018-12-6
[1-9]\d{3}-(1[0-2]|0?[1-9])-[[12]\d|3[01]|0?[1-9]]
# 匹配邮箱地址
[-\w.]+@([-\da-zA-Z]+\.)+[a-zA-Z\d]{2,6}
今日内容
递归函数I
#递归问题,os模块:查看一个文件夹下所有文件,这个文件夹下面还有文件夹,不能用walk
#D:\Typora
import os
def show_file(path):
name_lst=os.listdir(path)
for name in name_lst:
abs_path=os.path.join(path,name)
if os.path.isfile(abs_path):
print(name)
elif os.path.isdir(abs_path):
show_file(abs_path)
show_file('D:\Typora')
#递归问题,计算斐波那契数列,找第100个数
#1 1 2 3 5
def fib(n,a=1,b=1):
if n==1 or n==2:
return b
else:
return fib(n-1,b,a+b)
ret=fib(100)
print(ret)
#递归问题,os模块:计算一个文件夹下所有文件的大小,这个文件夹下面还有文件夹,不能用walk
#D:\Typora
import os
def dir_size(path):
size=0
name_lst=os.listdir(path)
# print(name_lst)
for name in name_lst:
abs_path=os.path.join(path,name)
if os.path.isfile(abs_path):
size += os.path.getsize(abs_path)
else:
ret=dir_size(abs_path)
size += ret
return size ret=dir_size('D:\Typora')
print(ret)
shutil模块
- 拷贝文件:shutil.copy2(原文件,现文件)
- 拷贝目录:shutil.copytree(原目录,现目录,ignore=xx)
- 删除目录:shutil.rmtree(目录,ignore=xx)
- 移动文件/目录:shutil.move
- 获得磁盘的使用空间
- 压缩文件夹:shutil.make_archive(压缩文件名,格式,路径)
- 解压:shutil.unpack_archive(压缩文件)
logging模块
为什么要写log?
- log是为了排错
- log用来做数据分析
举例:购物商城
- 什么时间买了什么商品
- 把哪些商品加入了购物车
- 一个用户登录时间地点
- 搜索了什么
- 什么时候关闭了软件
- 上述等操作都存到了数据库
- 做数据分析的内容--记录到日志
如果学生管理系统被某人删了某些东西,日志都有
用来记录用户的行为 - 数据分析
用来记录用户的行为 - 操作审计
排查代码中的错误
import logging
#输出内容是有等级的:默认处理warnning级以上的信息
logging.debug('debug message') #调试
logging.info('info message') #信息
logging.warning('warning message') #警告
logging.error('error message') #错误
logging.critical('critical message') #批判性
#无论希望日志里打印哪些内容,都得自己写,没有自动生成日志的事儿
日志等级的设置
logging.basicconfig(format='',datefmt='')
import logging
logging.basicConfig(format='%(asctime)s-%(name)s-%(levelname)s-%(module)s:%(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',
)
logging.warning('warning message test2')
#输出到文件,并且设置信息等级,handlers=[放文件操作符]
import logging
fh=logging.FileHandler('tmp.log',encoding='utf-8')
sh=logging.StreamHandler()
logging.basicConfig(format='%(asctime)s-%(name)s-%(levelname)s-%(module)s:%(message)s',
datefmt='%Y-%m-%d %H:%M:%S %p',
level=logging.DEBUG,
handlers=[fh,sh]
)
logging.warning('warning message test2')
logging.error('error message test2')
logging.critical('critical message test2')
日志的切分
明天学习
面向对象
代码总行数2325行
python21day的更多相关文章
随机推荐
- 基于React和Node.JS的表单录入系统的设计与实现
一.写在前面 这是一个真实的项目,项目已经过去好久了,虽然很简单,但还是有很多思考点,跟随着笔者的脚步,一起来看看吧.本文纯属虚构,涉及到的相关信息均已做虚构处理, 二.背景 人活着一定要有信仰,没有 ...
- 深度学习中常见的 Normlization 及权重初始化相关知识(原理及公式推导)
Batch Normlization(BN) 为什么要进行 BN 防止深度神经网络,每一层得参数更新会导致上层的输入数据发生变化,通过层层叠加,高层的输入分布变化会十分剧烈,这就使得高层需要不断去重新 ...
- 【Java例题】3.3 正整数分解
3.将一个正整数分解为连续多个正整数之和. 例如: 15=1+2+3+4+5 15=4+5+6 15=7+8 package chapter3; import java.util.*; public ...
- 编写Java程序,使用JDialog构造登录窗体
返回本章节 返回作业目录 需求说明: 实现思路: 定义用户信息实体类User. 创建LoginDemoStart主类,初始化UI. 从UI获取用户信息并保存到User实体. 实现代码:
- Elasticsearch单机安装Version7.10.1
1.说明 Elasticsearch单机安装, 基于Elasticsearch的7.10.1版本, 在Linux上安装Elasticsearch单机, 使用安装包elasticsearch-7.10. ...
- Foxmail:‘错误信息:由于连接方在一段时间后没有正确答复或连接的主机没有反应,连接尝试失败’的解决办法
每日必开-Foxmail 但是有连续半个多月未收到1封邮件 心想 大过年的 大家都不发邮件了 么 并未特别在意 直到该接收工资条的日子 我的Foxmail依然毫无动静 点了一下 收取 结果报如下错误: ...
- 总结 sql 的 并集、交集、差集
有两个表 ,表a ,表b , create table a { age int , name varchar(20) } ending=innodb; insert into a values(13 ...
- systemd学习及使用
什么是systemd? (译)systemd是linux系统的一组基础构件块.它提供了一个系统和服务的管理,它以PID 1 的形式运行并启动系统的其余部分.systemd 使用积极的并行化功能,使用s ...
- Go语言命名规范
一.变量命名规范 变量命名一般采用驼峰式,当遇到特有名词(缩写或简称,如DNS)的时候,特有名词根据是否私有全部大写或小写.例子: var apiClient var URLString 二.常量命名 ...
- SpringBoot学习笔记四之后台登录页面的实现
注:图片如果损坏,点击文章链接: https://www.toutiao.com/i6803542216150090252/ 继续之前完成的内容,首先创建一个常量类 常量类的内容 服务器端渲染 前后端 ...