Python之路_Day5

Python之路_Day5_课堂笔记

----------------------------------------------------------------------------------------------------

前期回顾:

一、python基础

二、基本数据类型

int

str

list

tuple

dict

set

三、函数式编程

四、装饰器

1、将func当作参数传递给装饰器,并执行

2、将装饰器函数的返回值重新赋值给func

----------------------------------------------------------------------------------------------------

本期内容:

一、作业重点

二、双层装饰器

三、模块

内置模块

自定义模块

第三方模块

四、字符串格式化

五、生成器和迭代器

六、其他

递归

----------------------------------------------------------------------------------------------------

一、作业重点

----------------------------------------------------------------------------------------------------

二、双层装饰器

双层装饰器小练习:

  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模块

利用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)

  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))

logging模块

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;)
  • %,当字符串中存在格式化标志时,需要用 %%表示一个百分号

  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位)

  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 = "\tI am \033[31m{:s}\033[0m \n\tAge \033[31m{:d}\033[0m".format(‘sandler‘,20)
  11. >>> print(s4)
  12. I am sandler
  13. Age 20

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

----------------------------------------------------------------------------------------------------

五、生成器和迭代器

1、生成器

  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)

  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、递归:一个函数调用另一个函数

  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    #数据,例如用户信息


来自为知笔记(Wiz)

时间: 2024-12-11 01:02:06

Python之路_Day5的相关文章

Python之路【第十七篇】:Django【进阶篇 】

Python之路[第十七篇]:Django[进阶篇 ] Model 到目前为止,当我们的程序涉及到数据库相关操作时,我们一般都会这么搞: 创建数据库,设计表结构和字段 使用 MySQLdb 来连接数据库,并编写数据访问层代码 业务逻辑层去调用数据访问层执行数据库操作 import MySQLdb def GetList(sql): db = MySQLdb.connect(user='root', db='wupeiqidb', passwd='1234', host='localhost')

Python之路【第九篇】:Python操作 RabbitMQ、Redis、Memcache、SQLAlchemy

Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached基于一个存储键/值对的hashmap.其守护进程(daemon )是用C写的,但是客户端可以用任何语言来编写,并通过memcached协议与守护进程通信. Memc

七日Python之路--第十二天(Django Web 开发指南)

<Django Web 开发指南>.貌似使用Django1.0版本,基本内容差不多,细读无妨.地址:http://www.jb51.net/books/76079.html (一)第一部分 入门 (1)内置数字工厂函数 int(12.34)会创建一个新的值为12的整数对象,而float(12)则会返回12.0. (2)其他序列操作符 连接(+),复制(*),以及检查是否是成员(in, not in) '**'.join('**')   或  '***%s***%d' % (str, int)

七日Python之路--第九天

众所周知,代码这东西不是看出来的.程序这东西只哟一个标准. 下面找点开源的东西看看,学习一下大婶们的犀利编码...... 推荐一下: 虽然有点老了:http://www.iteye.com/topic/405150,还有就是GitHub上面搜索一下Django就能出来很多,当然还有OSChina.只是有个问题,就是Django版本不同,具体的内容可能会有些不同,但大概还是相同的.领略即可,然后书写自己的代码. 首要的还是官方文档. 看着还是有些难度的.偶然发现一个不错的Blog:http://w

Python之路【第三篇】:Python基础(二)

Python之路[第三篇]:Python基础(二) 内置函数 一 详细见python文档,猛击这里 文件操作 操作文件时,一般需要经历如下步骤: 打开文件 操作文件 一.打开文件 1 文件句柄 = file('文件路径', '模式') 注:python中打开文件有两种方式,即:open(...) 和  file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open. 打开文件时,需要指定文件路径和以何等方式打开文件,打开后,即可获取该文件句柄,日后通过此文件句柄对该文件操作.

Python之路【第二篇】:Python基础(一)

Python之路[第二篇]:Python基础(一) 入门知识拾遗 一.作用域 对于变量的作用域,执行声明并在内存中存在,该变量就可以在下面的代码中使用. 1 2 3 if 1==1:     name = 'wupeiqi' print  name 下面的结论对吗? 外层变量,可以被内层变量使用 内层变量,无法被外层变量使用 二.三元运算 1 result = 值1 if 条件 else 值2 如果条件为真:result = 值1如果条件为假:result = 值2 三.进制 二进制,01 八进

Python之路【第十九篇】:爬虫

Python之路[第十九篇]:爬虫 网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用的名字还有蚂蚁.自动索引.模拟程序或者蠕虫. Requests Python标准库中提供了:urllib.urllib2.httplib等模块以供Http请求,但是,它的 API 太渣了.它是为另一个时代.另一个互联网所创建的.它需要巨量的工作,甚至包括各种方法覆盖,来完成最简单的任务. import

Python之路【第七篇】:线程、进程和协程

Python之路[第七篇]:线程.进程和协程 Python线程 Threading用于提供线程相关的操作,线程是应用程序中工作的最小单元. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 #!/usr/bin/env python # -*- coding:utf-8 -*- import threading import time   def show(arg):     time.sleep(1)     print 'thread'+str(arg)   for i in

Python之路【第八篇】:堡垒机实例以及数据库操作

Python之路[第八篇]:堡垒机实例以及数据库操作 堡垒机前戏 开发堡垒机之前,先来学习Python的paramiko模块,该模块机遇SSH用于连接远程服务器并执行相关操作 SSHClient 用于连接远程服务器并执行基本命令 基于用户名密码连接: + import paramiko transport = paramiko.Transport(('hostname', 22)) transport.connect(username='wupeiqi', password='123') ssh