Python之路_Day5

Python之路_Day5_课堂笔记
----------------------------------------------------------------------------------------------------
前期回顾:
一、python基础
二、基本数据类型
int
str
list
tuple
dict
set
三、函数式编程
四、装饰器
1、将func当作参数传递给装饰器,并执行
2、将装饰器函数的返回值重新赋值给func
----------------------------------------------------------------------------------------------------
本期内容:
一、作业重点
二、双层装饰器
三、模块
内置模块
自定义模块
第三方模块
四、字符串格式化
五、生成器和迭代器
六、其他
递归

----------------------------------------------------------------------------------------------------
一、作业重点





----------------------------------------------------------------------------------------------------
二、双层装饰器
9XQ(Z5)RLG@4I~UC766]AX7.jpg
O7LZ_INY(@APJKRVJUJI79A.png
F0)UNS$O9{8252I05~IL}BU.png
WV[2V(GNVKPJ]IZ45D]U212.png
双层装饰器小练习:
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. USER_INFO = {}
  5. def check_login(func):
  6. def inner(*args,**kwargs):
  7. if USER_INFO.get('is_login', None):
  8. ret = func(*args,**kwargs)
  9. return ret
  10. else:
  11. print('请登录')
  12. return inner
  13. def check_admin(func):
  14. def inner(*args,**kwargs):
  15. if USER_INFO.get('user_type',None) == 2:
  16. ret = func(*args,**kwargs)
  17. return ret
  18. else:
  19. print('权限不足')
  20. return inner
  21. @check_login
  22. @check_admin
  23. def index():
  24. print('index')
  25. index()

----------------------------------------------------------------------------------------------------
三、模块



  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. # lib/commons.py
  5. def f1():
  6. print("F1")
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. # mk_dy.py
  5. def login():
  6. print("login")
  7. def logout():
  8. print("logout")
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. # mokuai.py
  5. import mk_dy
  6. import lib.commons
  7. mk_dy.login()
  8. lib.commons.f1()

使用模块:
    先导入,后使用
py:模块
其他:类库
为什么要有模块
    将代码归类
导入模块的依据
    import sys
    sys.path
模块名称的重要性
    自定义模块不可以和内置模块重名
导入模块
    单模块
        import
    嵌套在文件夹下的
        from xxx import xxx
        from xxx import xxx as xxx

1、内置模块
序列化相关模块:
json模块
pickle模块
KZ(5)HW]8~55XEV[Y)F[0%0.png
利用requests获取http请求,并将结果利用json序列化成字典:
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. # requests 测试
  5. import requests
  6. import json
  7. response = requests.get('http://wthrcdn.etouch.cn/weather_mini?city=北京')
  8. response.encoding = 'utf-8'
  9. # print(response.text)
  10. dic = json.loads(response.text)
  11. print(dic)
T({A_X@BO9)AKE[VOS9}Z`K.png
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. import json
  5. r = json.dumps([11,22,33])
  6. print(r,type(r))
  7. li = '["sandler","yuli"]'
  8. ret = json.loads(li)
  9. print(ret,type(ret))
]JP89S1YY70UM4F{VMNOO4N.png
[HVF5W@~PAZ_5WBH]~UN@%X.png

logging模块

EF{X5MVG[XHOP6%X7Y%AL$N.png
(MIV(T(}@]~{]8P1B]}I[N0.png

2、自定义模块



3、第三方模块
安装方法:
    pip3 install requests
    源码 = 先下载源码包 = 解压 = 进入解压目录 = 执行 python setup.py install




----------------------------------------------------------------------------------------------------
四、字符串格式化
1、百分号方式
%[(name)][flags][width].[precision]typecode
(name)      可选,用于选择指定的key
flags          可选,可供选择的值有:
  • +       右对齐;正数前加正好,负数前加负号;
  • -        左对齐;正数前无符号,负数前加负号;
  • 空格    右对齐;正数前加空格,负数前加负号;
  • 0        右对齐;正数前无符号,负数前加负号;用0填充空白处
width         可选,占有宽度
.precision   可选,小数点后保留的位数
typecode    必选
  • s,获取传入对象的__str__方法的返回值,并将其格式化到指定位置
  • r,获取传入对象的__repr__方法的返回值,并将其格式化到指定位置
  • c,整数:将数字转换成其unicode对应的值,10进制范围为 0 <= i <= 1114111(py27则只支持0-255);字符:将字符添加到指定位置
  • o,将整数转换成 八  进制表示,并将其格式化到指定位置
  • x,将整数转换成十六进制表示,并将其格式化到指定位置
  • d,将整数、浮点数转换成 十 进制表示,并将其格式化到指定位置
  • e,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(小写e)
  • E,将整数、浮点数转换成科学计数法,并将其格式化到指定位置(大写E)
  • f, 将整数、浮点数转换成浮点数表示,并将其格式化到指定位置(默认保留小数点后6位)
  • F,同上
  • g,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是e;)
  • G,自动调整将整数、浮点数转换成 浮点型或科学计数法表示(超过6位数用科学计数法),并将其格式化到指定位置(如果是科学计数则是E;)
  • %,当字符串中存在格式化标志时,需要用 %%表示一个百分号

JTDO982S}BT_QC2HTWU{C_H.png
  1. tpl = "i am %s" % "alex"
  2. tpl = "i am %s age %d" % ("alex", 18)
  3. tpl = "i am %(name)s age %(age)d" % {"name": "alex", "age": 18}
  4. tpl = "percent %.2f" % 99.97623
  5. tpl = "i am %(pp).2f" % {"pp": 123.425556, }
  6. tpl = "i am %.2f %%" % {123.425556, }
2、Format方式
[[fill]align][sign][#][0][width][,][.precision][type]
fill           【可选】空白处填充的字符
align        【可选】对齐方式(需配合width使用)
  • <,内容左对齐
  • >,内容右对齐(默认)
  • =,内容右对齐,将符号放置在填充字符的左侧,且只对数字类型有效。 即使:符号+填充物+数字
  • ^,内容居中
sign         【可选】有无符号数字
  • +,正号加正,负号加负;
  • -,正号不变,负号加负;
  • 空格 ,正号空格,负号加负;
#            【可选】对于二进制、八进制、十六进制,如果加上#,会显示 0b/0o/0x,否则不显示
,            【可选】为数字添加分隔符,如:1,000,000
width       【可选】格式化位所占宽度
.precision 【可选】小数位保留精度
type         【可选】格式化类型
传入” 字符串类型 “的参数
  • s,格式化字符串类型数据
  • 空白,未指定类型,则默认是None,同s
传入“ 整数类型 ”的参数
  • b,将10进制整数自动转换成2进制表示然后格式化
  • c,将10进制整数自动转换为其对应的unicode字符
  • d,十进制整数
  • o,将10进制整数自动转换成8进制表示然后格式化;
  • x,将10进制整数自动转换成16进制表示然后格式化(小写x)
  • X,将10进制整数自动转换成16进制表示然后格式化(大写X)
传入“ 浮点型或小数类型 ”的参数
  • e, 转换为科学计数法(小写e)表示,然后格式化;
  • E, 转换为科学计数法(大写E)表示,然后格式化;
  • f , 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
  • F, 转换为浮点型(默认小数点后保留6位)表示,然后格式化;
  • g, 自动在e和f中切换
  • G, 自动在E和F中切换
  • %,显示百分比(默认显示小数点后6位)
O(2)UG`JF}(Z0CLTI0J8DLB.jpg
  1. tpl = "i am {}, age {}, {}".format("seven", 18, 'alex')
  2. tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex'])
  3. tpl = "i am {0}, age {1}, really {0}".format("seven", 18)
  4. tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18])
  5. tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18)
  6. tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18})
  7. tpl = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])
  8. tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)
  9. tpl = "i am {:s}, age {:d}".format(*["seven", 18])
  10. tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18)
  11. tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
  12. tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
  13. tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
  14. tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15)
  15. tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)
  1. >>> s1 = "--{:^20s}--{:+d}--{:x}".format('sandler',20,15)
  2. >>> print(s1)
  3. -- sandler --+20--f
  4. >>> s2 = "--{:*^20s}--{:+d}--{:#x}".format('sandler',20,15)
  5. >>> print(s2)
  6. --******sandler*******--+20--0xf
  7. >>> s3 = "numbers: {:b},{:o},{:d},{:x},{:X},{:%},{:d}".format(15, 15, 15, 15, 15, 15.87623, 2)
  8. >>> print(s3)
  9. numbers: 1111,17,15,f,F,1587.623000%,2
  10. >>> s4 = " I am 33[31m{:s}33[0m Age 33[31m{:d}33[0m".format('sandler',20)
  11. >>> print(s4)
  12. I am sandler
  13. Age 20

format方法比%方法强大,可以居中,可以二进制格式化,

----------------------------------------------------------------------------------------------------
五、生成器和迭代器
1、生成器
O3DM2PCB{C[7K33Q_FM`7MA.png
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. def func():
  5. print(111)
  6. yield 1
  7. print(222)
  8. yield 2
  9. print(333)
  10. yield 3
  11. ret = func()
  12. r1 = ret.__next__()
  13. print(r1)
  14. r2 = ret.__next__()
  15. print(r2)
  16. r3 = ret.__next__()
  17. print(r3)
6)~R_HN375@{HLN{G}XW_1X.jpg
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. def myrange(arg):
  5. start = 0
  6. while True:
  7. if start > arg:
  8. return
  9. yield start
  10. start += 1
  11. ret = myrange(3)
  12. r1 = ret.__next__()
  13. print(r1)
  14. r2 = ret.__next__()
  15. print(r2)
  16. r3 = ret.__next__()
  17. print(r3)
  18. r4 = ret.__next__()
  19. print(r4)
2、迭代器
不需要写,使用封装了迭代器的for循环就可以

----------------------------------------------------------------------------------------------------
六、其他
1、递归:一个函数调用另一个函数
(($@R$JVPL{0)GD`0L57HT2.png
(@4VY4DQHU1M)R)A7PXOU0S.png
SS{{PMGV6~P@4IDH_GF92}F.png
  1. #!/usr/bin/env python
  2. # -.- coding: utf-8 -.-
  3. # By sandler
  4. def func(n):
  5. n += 1
  6. if n >= 4:
  7. return 'end'
  8. return func(n)
  9. ret = func(1)
  10. print(ret)
思考题:使用递归实现“1*2*3*4*5*6*7”

2、冒泡排序



----------------------------------------------------------------------------------------------------
七、作业
作业需求:
模拟实现一个ATM + 购物商城程序
  1. 额度 15000或自定义
  2. 实现购物商城,买东西加入 购物车,调用信用卡接口结账
  3. 可以提现,手续费5%
  4. 每月22号出账单,每月10号为还款日,过期未还,按欠款总额 万分之5 每日计息
  5. 支持多账户登录
  6. 支持账户间转账
  7. 记录每月日常消费流水
  8. 提供还款接口
  9. ATM记录操作日志
  10. 提供管理接口,包括添加账户、用户额度,冻结账户等。。。

bin    #执行文件
    atm.py start    #每个程序不超过10行
    shopping.py
conf    #配置
    user_db.conf
    log.conf
modules    #模块,所有功能
log    #日志
db    #数据,例如用户信息






原文地址:https://www.cnblogs.com/sandler613/p/5561959.html