Python学习之路--模块2

hashlib

提供摘要算法的模块

import hashlib   # 提供摘要算法的模块
sha = hashlib.md5()
sha.update(b‘alex3714‘)
print(sha.hexdigest())
# aee949757a2e698417463d47acac93df

hashlib

不管算法多么不同,摘要的功能始终不变对于相同的字符串使用同一个算法进行摘要,得到的值总是不变的使用不同算法对相同的字符串进行摘要,得到的值应该不同不管使用什么算法,hashlib的方式永远不变
sha 算法 随着 算法复杂程度的增加 我摘要的时间成本空间成本都会增加

摘要算法密码的密文存储文件的一致性验证    在下载的时候 检查我们下载的文件和远程服务器上的文件是否一致    两台机器上的两个文件 你想检查这两个文件是否相等

加盐

import hashlib
md5 = hashlib.md5(bytes(‘盐‘,encoding=‘utf-8‘))
# md5 = hashlib.md5()
md5.update(b‘123456‘)
print(md5.hexdigest())

加盐

动态加盐用户名 密码使用用户名的一部分或者 直接使用整个用户名作为盐

动态加盐

import hashlib
md5 = hashlib.md5(bytes(‘盐‘,encoding=‘utf-8‘)+b‘dw‘)  # 加上需要加的字符
md5.update(b‘123456‘)
print(md5.hexdigest())

动态加盐

import hashilib 做摘要计算的 把字节类型的内容进行摘要理
md5 sha
md5 正常的md5算法 加盐的 动态加盐

文件的一致性校验这里不需要加盐

configparse

创建文件

[DEFAULT]
ServerAliveInterval = 45
Compression = yes
CompressionLevel = 9
ForwardX11 = yes

[bitbucket.org]
User = hg

[topsecret.server.com]
Port = 50022
ForwardX11 = no

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 configfile:

   config.write(configfile)

configparser

查找文件

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的键
    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‘)

config.remove_section(‘bitbucket.org‘)
config.remove_option(‘topsecret.server.com‘,"forwardx11")

config.set(‘topsecret.server.com‘,‘k1‘,‘11111‘)
config.set(‘yuan‘,‘k2‘,‘22222‘)

config.write(open(‘new2.ini‘, "w"))

logging

一键控制

排错的时候需要打印很多细节来帮助排错

严重的错误记录下来

有一些用户行为 有没有错都要记录下来

函数式简单配置

import logginglogging.debug(‘debug message‘)  # 低级别的  排错 信息logging.info(‘info message‘)        # 正常信息logging.warning(‘warning message‘)  # 警告信息logging.error(‘error message‘)    # 错误信息logging.critical(‘critical message‘)   #高级别的 严重错误信息
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‘)
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‘})
print(‘%s‘%(‘key‘,‘value‘))
    中文的乱码问题不能解决    不能同时往文件和屏幕上输出配置log对象 稍微有点复杂 能做的事情相对多
import logginglogger = 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)logger.debug(‘logger debug message‘)logger.info(‘logger info message‘)logger.warning(‘警告错误‘)logger.error(‘logger error message‘)logger.critical(‘logger critical message‘)

#程序充分解耦#让程序变得更灵活


原文地址:https://www.cnblogs.com/rssblogs/p/10990546.html

时间: 2024-10-04 13:07:34

Python学习之路--模块2的相关文章

Python 学习之路 - 模块概念,模块中的特殊变量,os、sys模块

模块概念 1 #注意:自定义的模块名不与标准模块名相同,若相同只会导入自定义模块 2 #单模块并在同一目录下: 3 #直接用 import 模块名,调用时用 模块名.方法名() 4 #嵌套在其他文件夹下: 5 #from xxx import xxx as 别名 6 import example 7 import lib.commons 8 from lib import commons as lib_commons 9 from src import commons as src_common

Python学习之路——模块

一.模块: 模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个函数才能完成(函数又可以在不同的.py文件中),n个 .py 文件组成的代码集合就称为模块. 如:os 是系统相关的模块:file是文件操作相关的模块 模块分为三种: 自定义模块 内置模块 开源模块 二.导入模块: import module from module.xx.xx import

Python学习之路-Day1-Python基础

Python学习之路第一天 学习内容: 1.Python简介 2.安装 3.第一个Python程序 4.变量 5.字符编码 6.用户输入 7.表达式if..else语句 8.表达式for语句 9.break和continue 10.while循环 11.字符串格式化 1.python简介 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承. 最新的TIOB

Python学习之路

Python学习之路 目录 Python学习之路[第一篇]:流程控制,用户交互,语法要求,变量,字符,注释,模块导入的使用 Python学习之路[第二篇]:文件,字符串,列表,元组,字典,集合的使用 更新中...

Python学习之路-装饰器&生成器&正则表达式

装饰器 通俗的讲,装饰器就是在不改变源代码基础上,给源代码增加新功能. 不改变函数的源代码.调用方式.返回值等,给函数增加新功能. 经典案例:登录装饰器, def login_decorator(func):     def inner():         if USER_TEMP["status"] == False:             print("\033[31;1m用户未登录,请先登录\033[0m")             login_atm()

Python学习之路【第一篇】-Python简介和基础入门

1.Python简介 1.1 Python是什么 相信混迹IT界的很多朋友都知道,Python是近年来最火的一个热点,没有之一.从性质上来讲它和我们熟知的C.java.php等没有什么本质的区别,也是一种开发语言,而且已经进阶到主流的二十多种开发语言的top 5(数据源自最新的TIOBE排行榜). 来头不小啊!二十多种主流的开发语言,我该从哪一个开始呢?人生苦短,let‘s python! 1.2 Python的由来和发展趋势 Python的前世源自鼻祖“龟叔”.1989年,吉多·范罗苏姆(Gu

Python学习之路——强力推荐的Python学习资料

资料一:程序媛想事儿(Alexia)总结 Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl.Tcl等动态语言一样,Python具备垃圾回收功能,能够自动管理内存使用.它经常被当作脚本语言用于处理系统管理任务和网络程序编写,然而它也非常适合完成各种高级任务. Python上手虽然容易,但与其它任何语言一样要学好Python并非一日之功.我的Pyth

Python 学习之路(二)

Python 学习之路(二) 以下所用的是Python 3.6 一.条件语句 简单判断 1 if 判断条件: 2 执行语句-- 3 else: 4 执行语句-- 复杂判断 1 if 判断条件1: 2 执行语句1-- 3 elif 判断条件2: 4 执行语句2-- 5 elif 判断条件3: 6 执行语句3-- 7 else: 8 执行语句4-- 二.循环语句 2.1 while语句 和其他语言一样,不同的是多了else语句.在 python 中,while - else 在循环条件为 false

Python 学习之路(三)

Python 学习之路(三) 以下所用的是Python 3.6 一.集合部分 集合是一个无序的,不重复的数据集合,主要用来去重,以及关系测试:交集,差集,并集等 1.1 关系操作 1.1.1 列表去重 可以给列表去重,例如: 1 set_demo = [1,2,3,4,5,3,2,1] # 列表 2 set_demo = set(set_demo) # 转换成集合,来去重 3 print(set_demo) 1.1.2 取交集 intersection()方法 可以获得两个集合的交集部分,例如: