zoukankan      html  css  js  c++  java
  • 面向对象总结、configparser配置文件模块、logging日志模块

    面向对象总结

    # 学习态度
    # python基础 2个月
    # html css js jq 1个月

    # 上课困

    # 学习方法 :
    # 列出知识点
    # 例子 写了哪些

    # 面向对象学了哪些块
    # 为什么要讲面向对象
    # 角色的不清晰,导致了方法的调用混乱
    # 重复的代码
    # 类和对象的定义 语法
    # 对象与对象之间的交互 : 人打狗 狗掉血
    # 面向对象的命名空间
    # 组合

    # 面向对象的三大特性
    # 继承 单继承 父类 子类
    #多继承 经典类和新式类的区别 抽象类和接口类(规范)
    # 多态(其他语言中的,python天生支持) 鸭子类型(list和tuple)
    # 封装 私有的 __变量
    # @property
    # @classmethod
    # @staticmethod

    # 面向对象的进阶
    # issubclass isinstance
    # 反射 hasattr getattr
    # 内置的方法:
    # 内置方法和内置函数和内置的数据类型以及内置的模块都有着千丝万缕的联系
    # __new__ 创建self 构造方法
    # __call__ 对象()

    # 写代码 两种思路
    # 面向过程
    # 面向函数
    # 面向对象

    知识教程地址:https://www.cnblogs.com/mys6/p/10584933.html

    configparse

    # configparse创建文件
    # import configparser
    # config = configparser.ConfigParser()
    # config["DEFAULT"] = {'ServerAliveInterval': '45',
    #                                    'Compression': 'yes',
    #                                    'CompressionLevel': '9',
    #                                   'ForwardX11':'yes'
    #                                     }
    # config['bitbucket.org'] = {'User':'hg'}
    #
    # config['topsecret.server.com'] = {'Host Port':'50022','ForwardX11':'no'}
    #
    # with open('example.ini', 'w') as f:
    #        config.write(f)

    查找文件
    # import configparser
    #
    # config = configparser.ConfigParser()
    # #---------------------------查找文件内容,基于字典的形式
    # # print(config.sections()) # []
    #
    # config.read('example.ini')
    # print(config.sections()) # ['bitbucket.org', 'topsecret.server.com']
    #
    # print('bytebong.com' in config) # False
    # print('bitbucket.org' in config) # True

    # print(config['bitbucket.org']["user"]) # hg
    # print(config['DEFAULT']['Compression']) #yes
    # print(config['topsecret.server.com']['ForwardX11']) #no
    #
    # print(config['bitbucket.org']) #<Section: bitbucket.org>
    #
    # for key in config['bitbucket.org']: # 注意,有default会默认default的键,无论打印哪一组先内容都打印出default的键,除非改名字
    # print(key)
    #
    # print(config.options('bitbucket.org')) # 同for循环,找到'bitbucket.org'下所有键
    #
    # print(config.items('bitbucket.org')) #找到'bitbucket.org'下所有键值对
    #
    # print(config.get('bitbucket.org','compression')) # yes get方法Section下的key对应的value

    增删改操作

    # import configparser
    # config = configparser.ConfigParser()
    # config.read('example.ini') # 读文件
    # config.add_section('yuan') # 增加section
    # config.remove_section('bitbucket.org') # 删除一个section
    # config.remove_option('topsecret.server.com',"forwardx11") # 删除一个配置项
    # config.set('topsecret.server.com','k1','11111')   在'topsecret.server.com'下新建一个键值"k1","1111"
    # config.set('yuan','k2','22222')
    # f = open('new2.ini', "w")
    # config.write(f) # 写进文件
    # f.close()

    logging

    # login 登录
    # log 日志
    # logging

    # 什么叫日志?
    # 日志 用来记录用户行为 或者 代码的执行过程
    # print

    # logging
    # 我能够“一键”控制
    # 排错的时候需要打印很多细节来帮助我排错
    # 严重的错误记录下来
    # 有一些用户行为 有没有错都要记录下来

    basicConfig

    import logging

    # logging.basicConfig(level=logging.WARNING,这里会打印该级别以上的日志
    #                                   format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
    #                                   datefmt='%a, %d %b %Y %H:%M:%S')

                                         filename='test.log'  隐藏这一段,屏幕打印,显示话写入文件

                                         filemode='a'
    #      try:
    #              int(input('num >>'))
    #     except ValueError:
    #             logging.error('输入的值不是一个数字')

    # logging.debug('debug message') # 低级别的 # 排错信息
    # logging.info('info message') # 正常信息
    # logging.warning('warning message') # 警告信息
    # logging.error('error message') # 错误信息
    # logging.critical('critical message') # 高级别的 # 严重错误信息

    # print('%(key)s'%{'key':'value'})   >>>value   格式化
    # print('%s'%('key','value'))

    # basicconfig 简单 能做的事情相对少
    # 中文的乱码问题
    # 不能同时往文件和屏幕上输出

    log对象

    # 配置log对象 稍微有点复杂 能做的事情相对多
    import logging
    logger = logging.getLogger()
    fh = logging.FileHandler('log.log',encoding='utf-8')
    sh = logging.StreamHandler() # 创建一个屏幕控制对象
    formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
    formatter2 = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s [line:%(lineno)d] : %(message)s')
    # 文件操作符 和 格式关联
    fh.setFormatter(formatter)
    sh.setFormatter(formatter2)
    # logger 对象 和 文件操作符 关联
    logger.addHandler(fh)
    logger.addHandler(sh)
    logging.debug('debug message') # 低级别的 # 排错信息
    logging.info('info message') # 正常信息
    logging.warning('警告错误') # 警告信息
    logging.error('error message') # 错误信息
    logging.critical('critical message') # 高级别的 # 严重错误信息

    # 程序的充分解耦
    # 让程序变得高可定制

    # zabbix

    # logging
    # 有5种级别的日志记录模式 :
    # 两种配置方式:basicconfig 、log对象

    # django框架

    # 作业 必须要写log

    29天后面的月考题目讲解未总结(待处理)

  • 相关阅读:
    django用户认证系统——基本设置1
    django用户认证系统——注册3
    django数据库设计
    修改linux最大文件句柄数
    LoadRunner监控Linux
    MySQL设置密码的三种方法
    JMeter学习-021-JMeter 定时器的应用
    mysql-bin.000001文件的来源及处理方法【转】
    js读取解析JSON数据
    关于查询区域标注区域总结
  • 原文地址:https://www.cnblogs.com/mys6/p/10745045.html
Copyright © 2011-2022 走看看