CSIC_716_20191115【内置函数、递归、模块、软件开发规范】

内置函数

map

map映射:语法结构(函数对象,可迭代对象)

依次从可迭代对象中取值,然后给函数做运算,再依次返回运算的结果.

ss = map(lambda x: x + x, [1, 2, 3])
print(ss)
try:
    print(ss.__next__())  # 2
    print(ss.__next__())  # 4
    print(ss.__next__())  # 6
    print(ss.__next__())
except StopIteration:
    print('完成')
----------------------------------------------------------
ss = map(lambda x, y: x + y, [1, 2, 3], [4, 5, 6])
print(ss)
try:
    print(ss.__next__())  # 5
    print(ss.__next__())  # 7
    print(ss.__next__())  # 9
    print(ss.__next__())
except StopIteration:
    print('完成')

reduce

reduce: 合并(函数对象,可迭代对象,初始值)

从可迭代对象中取出前两个值,传入函数进行运算,再与可迭代对象中的第三个值进行运算。

注意:上述操作均从初始值开始。

from functools import reduce

sum1 = reduce(lambda x, y: x + y, range(1, 101), 1000)
print(sum1)  # 6050

multi = reduce(lambda x, y: x * y, range(1, 5))
print(multi)  # 24

multi = reduce(lambda x, y: x * y, range(1, 5), 5)
print(multi)  # 120

filter

filter:语法结构:filter(函数对象,可迭代对象)

从可迭代对象中取值,放到函数中进行判断,如果返回结果为true,取值加入到filter返回的对象中。

def func1(x):
    if x > 'a':
        return True
    else:
        return False


ss = filter(func1, ['Bs', 'A', 'start', 'im', 'key'])
try:
    print(ss.__next__())
    print(ss.__next__())
    print(ss.__next__())
    print(ss.__next__())
except StopIteration:
    print('完成')
ss = filter(lambda x: x.startswith('i'), ['Bs', 'A','start', 'im', 'key'])

递归

递归是函数直接或者间接调用自身,是一种函数嵌套的形式。

如果不给边界值,程序会无线循环,造成内存溢出。

python中递归深度默认设置为1000。

可以通过sys.getrecursionlimit( )查看,也可以通过sys.setrecursionlimit( ) 设定递归深度。

# _*_ coding: gbk _*_
# @Author: Wonder
import sys
print(sys.getrecursionlimit())  #1000次数
sys.setrecursionlimit(1000)  # 设定最大递归次数1000,此处的值可以根据电脑修改

数学概念 已知f(0)=1, f(n) = f(n-1)+2 ,求f(5)的值,这是一则递归的表达式

用函数表达为

def f(n)
	if n==0
    	return 1
    return f(n-1)+2

f(5)

递归有两个过程,首先是由外到内层层找值(回溯),找到之后再由内到外层层返回(递推)。

模块

package

python中的包package,本质是一个有__ init__.py的文件夹。

package的作用:用于存放模块,可以更方便的管理模块。

模块

什么是模块

模块是一系列功能的结合体,本质上是一个.py文件。

模块的三种来源:

1、python内置的模块 2、第三方的模块 3、自己编写的模块

模块的四种表现形式:

1、使用python编写的.py文件。 2、编译后的共享DLL文件(库文件),c和c++的库。 3、包含__ init__.py的一组.py文件。 4、python解释器下的py文件。

如何创建编写并引用模块:

1、自己编写.py文件作为模块。 2、通过import关键字导入模块名,注意:在一个文件中多次import同一个模块不会有任何影响,一旦第一条import语句执行成功后,就会将模块加载到内存,后续的重名导入不会有任何作用。

模块的导入方式

import 模块名 as 模块别名

import time as t

也可以使用 from 包/模块名 import 模块/函数/变量/类

from functools import wraps 

导入的过程中极有可能发生循环导入的情况,类似于递归没有终止值。

此时可以根据Python的执行特点,调整import语句的顺序,提供循环导入的终止值

还可将import语句写进函数,在用到该函数时执行导入,本质上还是提供了循环导入的终止值。

模块在导入的时候发生的事情:

先执行当前的执行文件,在内存中开辟执行文件的名称空间

当执行到import语句时,开辟模块的名称空间,并将模块名称空间加载到内存,

再将模块的名称空间加载到内存。

软件开发目录规范

在写新项目是,都要新建一个项目工程和文件夹,要将项目文件夹作为项目根目录

-conf 配置

-core核心业务代码

-interface/api 接口

-db 文件数据

-lib 公共功能文件

-log 日志

-bin 启动目录

-readme.txt

posted @ 2019-11-15 17:05  HEU葉孤城  阅读(158)  评论(0编辑  收藏  举报