----------------------------------------------------------------------------------------------------
前期回顾:
一、python基础二、基本数据类型
intstrlisttupledictset
三、函数式编程四、装饰器
1、将func当作参数传递给装饰器,并执行2、将装饰器函数的返回值重新赋值给func
----------------------------------------------------------------------------------------------------
本期内容:
一、作业重点二、双层装饰器三、模块
内置模块自定义模块第三方模块
四、字符串格式化五、生成器和迭代器六、其他
递归
----------------------------------------------------------------------------------------------------
一、作业重点
----------------------------------------------------------------------------------------------------
二、双层装饰器
双层装饰器小练习:
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
USER_INFO = {}
def check_login(func):
def inner(*args,**kwargs):
if USER_INFO.get('is_login', None):
ret = func(*args,**kwargs)
return ret
else:
print('请登录')
return inner
def check_admin(func):
def inner(*args,**kwargs):
if USER_INFO.get('user_type',None) == 2:
ret = func(*args,**kwargs)
return ret
else:
print('权限不足')
return inner
@check_login
@check_admin
def index():
print('index')
index()
----------------------------------------------------------------------------------------------------
三、模块
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
# lib/commons.py
def f1():
print("F1")
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
- # mk_dy.py
def login():
print("login")
def logout():
print("logout")
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
# mokuai.py
import mk_dy
import lib.commons
mk_dy.login()
lib.commons.f1()
使用模块:
先导入,后使用
py:模块
其他:类库
为什么要有模块
将代码归类
导入模块的依据
import sys
sys.path
模块名称的重要性
自定义模块不可以和内置模块重名
导入模块
单模块
import
嵌套在文件夹下的
from xxx import xxx
from xxx import xxx as xxx
1、内置模块
序列化相关模块:
json模块
pickle模块
利用requests获取http请求,并将结果利用json序列化成字典:
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
# requests 测试
import requests
import json
response = requests.get('http://wthrcdn.etouch.cn/weather_mini?city=北京')
response.encoding = 'utf-8'
# print(response.text)
dic = json.loads(response.text)
print(dic)
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
import json
r = json.dumps([11,22,33])
print(r,type(r))
li = '["sandler","yuli"]'
ret = json.loads(li)
print(ret,type(ret))
logging模块
2、自定义模块
3、第三方模块
安装方法:
pip3 install requests
源码 = 先下载源码包 = 解压 = 进入解压目录 = 执行 python setup.py install
----------------------------------------------------------------------------------------------------
四、字符串格式化
1、百分号方式
%[(name)][flags][width].[precision]typecode
(name) 可选,用于选择指定的key
flags 可选,可供选择的值有:
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;)
- %,当字符串中存在格式化标志时,需要用 %%表示一个百分号
tpl = "i am %s" % "alex"
tpl = "i am %s age %d" % ("alex", 18)
tpl = "i am %(name)s age %(age)d" % {"name": "alex", "age": 18}
tpl = "percent %.2f" % 99.97623
tpl = "i am %(pp).2f" % {"pp": 123.425556, }
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位)
tpl = "i am {}, age {}, {}".format("seven", 18, 'alex')
tpl = "i am {}, age {}, {}".format(*["seven", 18, 'alex'])
tpl = "i am {0}, age {1}, really {0}".format("seven", 18)
tpl = "i am {0}, age {1}, really {0}".format(*["seven", 18])
tpl = "i am {name}, age {age}, really {name}".format(name="seven", age=18)
tpl = "i am {name}, age {age}, really {name}".format(**{"name": "seven", "age": 18})
tpl = "i am {0[0]}, age {0[1]}, really {0[2]}".format([1, 2, 3], [11, 22, 33])
tpl = "i am {:s}, age {:d}, money {:f}".format("seven", 18, 88888.1)
tpl = "i am {:s}, age {:d}".format(*["seven", 18])
tpl = "i am {name:s}, age {age:d}".format(name="seven", age=18)
tpl = "i am {name:s}, age {age:d}".format(**{"name": "seven", "age": 18})
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
tpl = "numbers: {:b},{:o},{:d},{:x},{:X}, {:%}".format(15, 15, 15, 15, 15, 15.87623, 2)
tpl = "numbers: {0:b},{0:o},{0:d},{0:x},{0:X}, {0:%}".format(15)
tpl = "numbers: {num:b},{num:o},{num:d},{num:x},{num:X}, {num:%}".format(num=15)
>>> s1 = "--{:^20s}--{:+d}--{:x}".format('sandler',20,15)
>>> print(s1)
-- sandler --+20--f
>>> s2 = "--{:*^20s}--{:+d}--{:#x}".format('sandler',20,15)
>>> print(s2)
--******sandler*******--+20--0xf
>>> s3 = "numbers: {:b},{:o},{:d},{:x},{:X},{:%},{:d}".format(15, 15, 15, 15, 15, 15.87623, 2)
>>> print(s3)
numbers: 1111,17,15,f,F,1587.623000%,2
>>> s4 = " I am 33[31m{:s} 33[0m Age 33[31m{:d} 33[0m".format('sandler',20)
>>> print(s4)
I am sandler
Age 20
format方法比%方法强大,可以居中,可以二进制格式化,
----------------------------------------------------------------------------------------------------
五、生成器和迭代器
1、生成器
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
def func():
print(111)
yield 1
print(222)
yield 2
print(333)
yield 3
ret = func()
r1 = ret.__next__()
print(r1)
r2 = ret.__next__()
print(r2)
r3 = ret.__next__()
print(r3)
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
def myrange(arg):
start = 0
while True:
if start > arg:
return
yield start
start += 1
ret = myrange(3)
r1 = ret.__next__()
print(r1)
r2 = ret.__next__()
print(r2)
r3 = ret.__next__()
print(r3)
r4 = ret.__next__()
print(r4)
2、迭代器
不需要写,使用封装了迭代器的for循环就可以
----------------------------------------------------------------------------------------------------
六、其他
1、递归:一个函数调用另一个函数
#!/usr/bin/env python
# -.- coding: utf-8 -.-
# By sandler
def func(n):
n += 1
if n >= 4:
return 'end'
return func(n)
ret = func(1)
print(ret)
思考题:使用递归实现“1*2*3*4*5*6*7”
2、冒泡排序
----------------------------------------------------------------------------------------------------
七、作业
作业需求:
模拟实现一个ATM + 购物商城程序
- 额度 15000或自定义
- 实现购物商城,买东西加入 购物车,调用信用卡接口结账
- 可以提现,手续费5%
- 每月22号出账单,每月10号为还款日,过期未还,按欠款总额 万分之5 每日计息
- 支持多账户登录
- 支持账户间转账
- 记录每月日常消费流水
- 提供还款接口
- ATM记录操作日志
- 提供管理接口,包括添加账户、用户额度,冻结账户等。。。
bin #执行文件
atm.py start #每个程序不超过10行
shopping.py
conf #配置
user_db.conf
log.conf
modules #模块,所有功能
log #日志
db #数据,例如用户信息