day11函数的进阶动态参数,命名空间,作用域,第一类对象
一、习题收藏
5、写函数,计算传入字符串中【数字】、【字母】、【空格】 以及 【其他】的个数,并返回结果。
# def func4(s):
# dic = {
# 'num':0,'alpha':0,'space':0,'others':0
# }
# for i in s:
# if i.isdigit():
# dic['num'] += 1
# elif i.isalpha():
# dic['alpha'] +=1
# elif i.isspace():
# dic['space'] += 1
# else:
# dic['others'] += 1
# return dic
# s = 'asdjk2330 sdjkfh#$^&'
# ret = func4(s)
# print(ret)
# 6、写函数,检查用户传入的对象(字符串、列表、元组)的每一个元素是否含有空内容,并返回结果。
# def func5(s_l_t):
# if s_l_t:
# for i in s_l_t:
# if not i and i != 0 and i != False:
# return True
# else:
# return True # 7、写函数,检查传入字典的每一个value的长度,如果大于2,那么仅保留前两个长度的内容,并将新内容返回给调用者。
# dic = {"k1": "v1v1", "k2": [11,22,33,44]}
# PS:字典中的value只能是字符串或列表
# def func6(dic):
# for k in dic:
# value = dic[k]
# if len(value) > 2:
# dic[k] = value[:2]
# return dic
# def func6(dic):
# for k in dic:
# dic[k] = dic[k][:2]
# return dic
# dic = {"k1": "v1v1", "k2": [11,22,33,44]}
# print(func6(dic))
# 8、写函数,接收两个数字参数,返回比较大的那个数字。
# a = 1
# b = 2
# def func7(a,b):
# if a > b:
# return a
# else:
# return b
# print(func7(1,1))
#
# #三元运算符
# c = 0
# if a>b:
# c = a
# else:
# c = b #新知识:重要程度五颗星*****
# c = a if a>b else b # 三元运算符 三元运算表达式
初始函数的作业题
def fun(a,b):
c = a if a>b else b # 三元运算符 三元运算表达式
return c
print(fun(1,2)) #2
二、动态参数
#动态参数
#*args :接收所有按照位置传的参数,接收到的是参数组成的元祖
#*args :接收所有按照位置传的参数,接收到的是参数组成的元祖
def func1(*args):
print(args)
func1('name',18,'e') # args = ('name', 18, 'e')
# 注:名字不一定是args 这是使用习惯,方便代码阅读
# 注:如果调用args时候前边加了一个* 便是将其迭代的形式变为形参 字符串前加*会变成单个元素
#注 :*args 在位置参数之后。关键字参数的前边
def func1(*args):
print(*args)
func1(*('name',18,'e')) #name 18 e
#传入的参数也可以用*打散
def my_sum(*args): #求合
# print(args)
# # sum_2 = 0
# # for i in args:
# # sum_2 += i
# # return sum_2
# l = [1,24,5,7]
可以求和
#**kwargs :接收所有按照关键字传的参数,接收到的是参数组成的字典
#**kwargs :接收所有按照关键字传的参数,接收到的是参数组成的字典
def func1(**kwargs):
print(kwargs)
func1(**{'abc':2,'bcd':3}) #{'a': 2, 'b': 3} 如果用*号得到的是key的参数
#所有的参数的顺序:位置参数,*args,默认参数,**kwargs
#keywords must str
#顺序:
#在调用函数的时候,可以打散:*l(按顺序打散)、**dic(打散)
#所有的参数的顺序:位置参数,*args,默认参数,**kwargs
二 、命名空间
#namespace 命名空间,名称空间
#局部命名空间:每一个函数都拥有自己的命名空间
#全局命名空间:写在函数外面的变量名
#内置命名空间:python解释器启动之后就可以使用的名字
#python的解释器要运行起来
#加载顺序:
# 先所有内置命名空间的中的名字-->然后按照顺序加载全局命名空间中的名字
#局部命名空间中的名字:在调用函数的时候产生,并且随着调用的结束而消失
如下代码的加载顺序:
# func(1,2,3,4,5)
# def f1(): 1
# a = 1 3
# def f2(): 4
# def f3(): 6
# a = 3 8
# print(a) 9
# f3() 7
# f2() 5
# f1() 2
三、函数的嵌套
嵌套内部的函数不能直接被外部调用,只能由他的上一层函数调用,或者自身将函数名返回到外层
#函数的嵌套定义
# def func():
# def qqxing():
# print('我是qqxing')
# qqxing()
# func() # print(len('123'))
# def len(x):
# print('***%s***'%x)
#
# len('123') #函数的嵌套定义
# n = 0
# def func1():
# def func2():
# print(n)
# func2()
#
# func1()
#fun2() 会报错
四、作用域
#作用域:一个名字可以使用的区域
#全局作用域:内置名字空间和全局名字空间中的名字都属于全局作用域
#局部作用域:局部名字空间中的名字属于局部作用域
#局部作用域可以使用全局作用域中的变量
#而全局作用域不能使用局部作用域中的变量
#局部作用域中还可以嵌套更小的局部作用域
#作用域链:小范围作用域可以使用大范围的变量,但作用域链是单向的,不能反向应用
# func1()
# def func():
# a = 10
# b = 20
# print(locals()) #保存了当前作用域中变量
# print(globals()) # n = 10
# m = 22
# print(globals()) #保存了在全局作用域中的名字和值
# func() #globals() #保存了在全局作用域中的名字和值
#locals() #中的内容会根据执行的位置来决定作用域中的内容
#如果在全局执行
#globals和locals打印的结果是一致的
如果局部作用域中的想修改全部变量,那么用globals 如果局部内层函数想修改外层函数那么用nonlocals
n = 1
def func2():
n = 2
def func3():
nonlocal n # 使用nonlocak前,本层函数不能出现该变量
n+=1
#print(n)
#global n # 使用nonlocak前,所有层函数不能出现该变量
n += 10
func3()
print(n)
func2()
print(n)
五、第一类对象(函数名)
#第一类对象的概念:
#函数名可以赋值
#可以作为一个数据结构的元素
#可以作为一个函数的参数
#可以作为一个函数的返回值
def func():
print('in func')
return 10 def func2(arg):
arg()
return arg f = func2(func)
f() #可以作为参数传递
def f1():
pass
def f2():
pass
def f3():
dic = {'alex':f1,'tai':f2}
name = input('请输入账户名:')
if name in dic:
dic[name]()
f3()

day11函数的进阶动态参数,命名空间,作用域,第一类对象的更多相关文章
- 函数的进阶(动态参数,命名空间和作用域,函数的嵌套,gloabal和nonlocal关键字)
1. 函数参数--动态传参 昨天已经解过了传参, 如果需要给一个函数传参,而参数又是不确定的. 或者我们给一个函数传很多参数, 我的形参就要写很多, 写起来就很麻烦, 这时我们可以考虑使用动态参数.形 ...
- python 全栈开发,Day10(动态参数,命名空间,作用域,函数嵌套)
一.动态参数 def func(a,b,c,d,e,f,g): pass func(1,2,3,4,5,6,7) 如果加30个参数呢?有没有万能的参数,可以代表一切参数呢? *args 动态参数,万能 ...
- python 函数的动态参数 命名空间,作用域以及函数嵌套,global和nonlocal (重点)
*** 坚持坚持,即使你不太强*** 1.函数的动态传参 2.函数的命名空间及作用域 3.函数嵌套 4.global和nonlocal关键字 一.函数的动态传参 1. *args: 位置参数动态传参, ...
- 【学习笔记】--- 老男孩学Python,day10, 函数, 动态参数 命名空间\作用域 global nonlocal
1. 动态参数 位置参数的动态参数: *args 关键字参数的动态参数 : **kwargs 顺序:位置---*args---默认值---**kwargs 在形参上*聚合, **聚合 在实参上*打散, ...
- python基础学习Day10 函数形参的动态参数、*args **kwargs 命名空间 global 与 nonlocal
一.函数形参的动态参数 原因:为了拓展,对于实参数量不固定,故需要万能参数,即动态参数, *args **kwargs # def sum1(*args): # 在函数定义时,在*位置参数,聚合. ...
- python函数知识二 动态参数、函数的注释、名称空间、函数的嵌套、global,nonlocal
6.函数的动态参数 *args,**kwargs:能接受动态的位置参数和动态的关键字参数 *args -- tuple *kwargs -- dict 动态参数优先级:位置参数 > 动态位置参数 ...
- Python学习5——抽象,涉及抽象和结构、函数的自定义、参数、作用域、递归
此处将抽象和结构.自定义函数.参数的使用.作用域.递归放在一起学习,看起来很怪是不是? 但实际上这几者之间是有紧密联系的,不然Python基础教程(第三版)的作者为什么会把它们放在一起哪?手动滑稽 好 ...
- javascript 红宝书笔记之函数、变量、参数、作用域
ECMAScript 不介意传进来多少个参数,也不介意传进来的参数类型. 理解参数: 命名的参数只提供便利,不是必需的. ECMAScript 的变量包含两种不同的数据类型的 ...
- function(函数)中的动态参数
我们可向函数传递动态参数,*args,**kwargs,首先我们来看*args,示例如下: 1.show(*args) def show(*args): print(args,type(arg ...
随机推荐
- javascript快速入门16--表格
表格的层次结构 <table border="1"> <caption>表格标题</caption> <thead> <tr& ...
- Actionscript 3 自定义 matedata
metadata就是元数据 反应一个类本质的属性 可以通过describeType(obj)来得到反应该对象的xml 要自定义元数据,如[MyMatedata()] package { public ...
- solr copyfield字段使用实践
1.使用场景 比如我们现在有一个文档,有title.author.area.keyword.link等字段.现在要把这个文档索引到 solr中,为了方便对author.area.keyword进行搜索 ...
- NDK官方开发指南翻译之 NDK_GDB
这几天看JNI,没有基础,那真是难受--把看到的相关资料记录一下,也分享给刚開始学习的人. 'ndk-gdb' Overview 重要:假设你要调试线程相关的程序.请阅读以下的'Thread Supp ...
- PostgreSQL学习资料
我的PostgreSQL学习笔记:http://note.youdao.com/share/?id=2e882717fc3850be9af503fcc0dfe7d0&type=notebook ...
- 微信团队分享:iOS版微信是如何防止特殊字符导致的炸群、APP崩溃的?
本文来自微信开发团队yanyang的技术分享. 1.引言 相信大家都遇到过一段特殊文本可以让iOS设备所有app闪退的经历.前段时间大年初一,又出现某个印度语字符引起iOS11系统奔溃,所幸iOS版微 ...
- Linux 多线程环境下 进程线程终止函数小结(转)
pthread_kill: pthread_kill与kill有区别,是向线程发送signal.,大部分signal的默认动作是终止进程的运行,所以,我们才要用signal()去抓信号并加上处理函数. ...
- Tomcat 5常用优化和配置
Tomcat 5常用优化和配置 1.JDK内存优化:Tomcat默认可以使用的内存为128MB,Windows下,在文件{tomcat_home}/bin/catalina.bat,Unix下,在文件 ...
- iOSeasy造成循引用的场景
场景一 :NStimer timer就是一个能在从如今開始的未来的某一个时刻又或者周期性的运行我们指定的方法的对象 NSTimer运行的必要条件:相应线程的RunLoop要开启,mode要相应 以下看 ...
- mybatis+oracle的批量插入
// 批量插入,手动控制事务 SqlSession batchSqlSession = null; try { batchSqlSession = sqlSessionTemplate.getSqlS ...