内容回顾

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行

最新文章

  1. Spring MVC学习
  2. JS控制,返回上一页之后强行刷新一次
  3. php的函数和数组
  4. 利用DotSpatial发布WMS, WFS服务
  5. 初步理解JNDI
  6. Azure Automation (3) 定期将某个Azure订阅下的所有虚拟机开关机
  7. Webview 与h5的交互
  8. 在Eclipse中使用MAT分析Android程序内存使用状况(转)
  9. 【练习】增加日志组数至4组,且每组日志成员大小为50M,每组2个成员。
  10. 浅谈dataGridView使用,以及画面布局使用属性,对datagridview进行增删改查操作,以及委托使用技巧
  11. poj3006 筛选法求素数模板(数论)
  12. day23_雷神_git
  13. 004_Python之all()\any()
  14. HTML基础【3】:列表标签
  15. 从0开始搭建vue+webpack脚手架(三)
  16. LEARN HOW TO HACK
  17. mysql优化之伪哈希索引
  18. 纯CSS + 媒体查询实现网页导航特效
  19. 关于直播学习笔记-002-Red5 &amp; Sewise Player &amp; Wirecast
  20. 如何获取e.printStackTrace()的内容

热门文章

  1. 【LeetCode】717. 1-bit and 2-bit Characters 解题报告(Python)
  2. 【LeetCode】297. Serialize and Deserialize Binary Tree 解题报告(Python)
  3. [LeetCode]485. Max Consecutive Ones 找到最大的连续的1的个数
  4. Python基础入门(8)- Python模块和包
  5. ADVERSARIAL EXAMPLES IN THE PHYSICAL WORLD
  6. oralce索引的使用
  7. uniapp中拿到base64转blob对象,或base64转bytes字节数组,io操作写入字节流文件bytes
  8. &lt;数据结构&gt;XDOJ316.多点测试的写法
  9. 【jvm】07-偏向锁、轻量锁、重量锁到底是啥?
  10. 基于Spring MVC + Spring + MyBatis的【学生信息管理系统】