• 常用模块:hashlib,subprocess,configparser。


    一  hashlib模块

    那么我们前面学习数据类型的时候,也讲了hash,可变类型不可hash;不可变类型可hash。

    我们知道hash是一种算法,接收传入的内容经过运算之后得到一个hash值,我们可以把hash看作一个工厂,送进去原料,出来时包装之后的成品。

    hash的特点:

    1 只要传入的内容一样,得到的hash值就是一样的,(可以分多次传入,只要传入的值一样,得到的hash值就一样),这个特点可以用来检测文件的完整性。

    2不能由hash值返解出内容,这也是我们可以用hash加密的一个原因。

    3 只要使用的hash算法不变(hash有多种算法:md5,sha256,sha384等。。。)得到的hash值得个数是一定的,不论文件的内容如何变化。

    密码加盐:

    hash还有一种升级加密办法:

    就是密码加盐,密码加盐的本质就是在我们需要加密的内容基础上再加其他的固定的内容。

    二 subprocess模块

    我们在cmd终端命令行中有如下操作:

    1 tasklist会向屏幕输出我们当前电脑所有的程序运行情况,那么如果我们想要单独拿到某一个程序就需要使用一个管道'''|'''
    
    tasklist  |  findstr  pycharm
    
    2 taskkill  /?用来查看命令进程
    
    taskkill  /PID用来结束进程
    
    taskkill  /F/PID用来强制结束进程

    我们通过一段代码来说明subprocess的应用:

    import subprocess

    obj=subprocess.Popen('dfghgir',#代表我们所输入的命令,可以对也可以错 shell=True, stdout=subprocess.PIPE,#对的情况下从这个管出来 stderr=subprocess.PIPE#错的情况下从这个管出来 ) res1=obj.stdout.read()#将内容读取出来赋给res1 print(res1.decode('gbk'))#因为res1位utf-8格式的,所以会出现乱码,需要解码成‘gbk’res2=obj.stderr.read() print(obj.stderr.read())###b"'dfghgir' xb2xbbxcaxc7xc4xdaxb2xbfxbb print(obj.stderr.read())###b‘’那么我们只得到一个结果,所以第二个没有内容输出。

    三 configparser模块

    有一文件‘a.txt’
    [section1]
    k1 = v1
    k2:v2
    user=egon
    age=18
    is_admin=true
    salary=3.341

    [section2]
    k1 = v1
    k2:v2
    user=alex
    age=20
    is_admit=false
    salary=4.454
    程序:

    import
    configparser config=configparser.ConfigParser() print(config.read('a.txt')) # 查看标题 res=config.sections() #['section1', 'section2']查看文本中的标签 section print(res) res1=config.options('section1') print(res1)#输出的为section1下的key。那么既然能拿到key我们通过可以也能拿到value res2=config.items('section1')#输出section1下的所有内容。 print(res2) res3=config.get('section1','age')#通过get得到section1下的age对应的值。 print(res3) res0=config.getboolean('section1','is_admin')#得到标题下的is_admin的值,判断是不是bool类型。 print(res0) res5=config.getfloat('section1','salary')#如果所对应的值不是浮点型则会报错。 print(res5) res4=config.getint('section1','age') print(res4)

    四 面向对象:

    优点是

    解决了程序的扩展性。对某一个对象单独修改,会立刻反映到整个体系中,如对游戏中一个人物参数的特征和技能修改都很容易。

    缺点:

    1. 编程的复杂度远高于面向过程,不了解面向对象而立即上手基于它设计程序,极容易出现过度设计的问题。一些扩展性要求低的场景使用面向对象会徒增编程难度,比如管理linux系统的shell脚本就不适合用面向对象去设计,面向过程反而更加适合。

    2. 无法向面向过程的程序设计流水线式的可以很精准的预测问题的处理流程与结果,面向对象的程序一旦开始就由对象之间的交互解决问题,即便是上帝也无法准确地预测最终结果。于是我们经常看到对战类游戏,新增一个游戏人物,在对战的过程中极容易出现阴霸的技能,一刀砍死3个人,这种情况是无法准确预知的,只有对象之间交互才能准确地知道最终的结果。

    应用场景:需求经常变化的软件,一般需求的变化都集中在用户层,互联网应用,企业内部软件,游戏等都是面向对象的程序设计大显身手的好地方

    面向对象的程序设计并不是全部。对于一个软件质量来说,面向对象的程序设计只是用来解决扩展性。

     

    类在定义阶段特殊的地方是:在定义类的阶段立刻执行类体内的代码,然后将产生的名字存放于类名称空间中。

    类与类别:

    类即类别、种类,是面向对象设计最重要的概念,对象是特征与技能的结合体,而类则是一系列对象相似的特征与技能的结合体

    那么问题来了,先有的一个个具体存在的对象(比如一个具体存在的人),还是先有的人类这个概念,这个问题需要分两种情况去看

    在现实世界中:先有对象,再有类

    世界上肯定是先出现各种各样的实际存在的物体,然后随着人类文明的发展,人类站在不同的角度总结出了不同的种类,如人类、动物类、植物类等概念

    也就说,对象是具体的存在,而类仅仅只是一个概念,并不真实存在

    在程序中:务必保证先定义类,后产生对象

    这与函数的使用是类似的,先定义函数,后调用函数,类也是一样的,在程序中需要先定义类,后调用类

    不一样的是,调用函数会执行函数体代码返回的是函数体执行的结果,而调用类会产生对象,返回的是对象

  • 相关阅读:
    十五行Python代码实现批量下载好看的视频,嘎嘎好看
    利用PYTHON实现科学占卜
    如何开发一个分布式内存数据库(一)
    AE中的线符号渲染
    AE中的面符号(填充符号)渲染
    Excel批量转Word
    AE中的点符号渲染
    搭建nuget服务器(三):使用nuget下载制作的package
    搭建nuget服务器(二):制作package
    搭建nuget服务器(一):搭建nuget应用服务
  • 原文地址:https://www.cnblogs.com/zhangsanfeng/p/8779157.html
Copyright © 2020-2023  润新知