#一个函数何以接受多个参数
#无参数
#show(): ---> 执行:show()
#传入一个参数
def show(arg):
print(arg)
#执行
show(123)
#传入两个参数
def show(arg,aaa):
print(arg,aaa)
#执行
show(123,'bbb')
#函数的默认参数
#设置一个默认参数为:999
def show(a1,a2=999):
print(a1,a2)
#执行
show(111,'')
show(111)
#说明:第二个参数a2 指定了默认参数999,在执行的时候 如果 第二个传入参数了 就会使用传入的参数,如果第二个没有传入参数,那函数就会使用默认参数 999
#注意:默认参数必须要写在最后,比如: show(a2=999,a1): 这样就会报语法错误
#指定参数
def show(a1,a2):
print(a1,a2)
#执行
show(111,'')
#默认是把 第一个 111 传给 a1,第二个参数 222传给 a2
show(a2=999,a1=123)
#这样就会把第一个参数传给 a2,, 第二个参数传给 a1
#动态参数
def show(arg):
print(arg)
n = [11,22,33,44]
#执行
show(n)
#参数 可以传入,字典,元素,列表,元祖
#自动转化元组
def show(*arg):
print(arg,type(arg))
show(1)
#指定 show(*arg) 一个星号 把传入的所有参数自动转化为元组
#自动转化字典
def show(**arg):
print(arg,type(arg))
show(n1=78,uu=123)
#指定 show(**arg) 二个星号 把传入的所有参数自动转化为字典
#一个星号和两个星号的组合,会自动把对应传入值 封装到 对应的参数里
#如果 一个星号的参数和两个星号的参数同时存在,必须把一个星号的参数放在第一个位置,
def show(*args,**kwargs):
print(args,type(args))
print(kwargs,type(kwargs))
show(11,22,33,44,n1=888,n2=999)
 #练习
def show(*args,**kwargs):
print(args,type(args))
print(kwargs,type(kwargs))
L = [11,22,33,44]
d = {'n1':111,'n2':222,'n3':333}
#注意: 如下传入参数的方法会将 L d 两个变量当做参数传入 show 函数接受到这两个变量后 就会把 两个变量自动转换成 一个元组,这个元组 包含 列表 L,字典d,而 真正的**kwargs里是空的
show(L,d)
#输出:
#([11, 22, 33, 44], {'n1': 111, 'n2': 222, 'n3': 333}) <class 'tuple'>
#{} <class 'dict'>
#正确的传入方式:
show(*L,**d)
#输出:
#(11, 22, 33, 44) <class 'tuple'>
#{'n1': 111, 'n2': 222, 'n3': 333} <class 'dict'>

 动态参数实现字符串格式化

#使用一个 * 元组来实现字符串格式化

#动态参数实现字符串格式化
#字符串format 方法来格式化,可以传入 元组,字典
#这里的 0 1 定义为占位符
a = "{0} is {1}"
w = ["asd",["mmmm"]]
ret = a.format(['a1','a2'],{'w1':'eee4'})
w1 = a.format(*w)
print(ret)
#输出:
#['a1', 'a2'] is {'w1': 'eee4'}
print(w1)
#输出:
#asd is ['mmmm']

#使用两个 * 字典来实现字符串格式化

#使用两个 * 字典来实现字符串格式化
#如果是字典的形式来进行字符串的格式化,这里的 占位符 就不是0 1 来定义了,而是 keys value 的形式来定义了 a = "{nameK} is {acterV}"
result = a.format(nameK='K',acterV='V')
print(result)
#输出:
#K is V a = "{nameK} is {acterV}"
b = {"nameK":"KG","acterV":"VG"}
result = a.format(**b)
print(result)
#输出:
#KG is VG
#lambda表达式,简单函数的表示
#创建形式参数a
#函数内容, a+1 并把结果 return回去
func = lambda a: a+1
#形式参数,可以是多个 一个a 一个 b,
print(func(5))
 

												

函数-->指定函数--->默认函数--->动态函数--> 动态参数实现字符串格式化-->lambda表达式,简单函数的表示的更多相关文章

  1. C++函数四( 具有默认参数值的函数)

    在C++语言中,可以设置函数形参的默认值,在调用函数时,若明确给出了实参的值,则使用相应实参的值;若没有给出相应实参的值,则使用默认的值.这将为函数调用带来方便和灵活. [示例] #include&l ...

  2. day10-Python运维开发基础(函数嵌套、nonlocal声明局部变量、闭包、locals/globals、lambda表达式)

    1. 函数的嵌套与nonlocal 声明局部变量 # ### 函数的嵌套 """ 函数和函数之间可以互相嵌套: 嵌套在内层的叫做内函数 乔涛在外层的叫做外函数 " ...

  3. python(3)-动态参数实现字符串格式化

    s1 = "{0} ===> {1}" s = s1.format('lilei', 'boy') print(s) l = ['lilei', 'boy'] s = s1. ...

  4. Python-Day3知识点——深浅拷贝、函数基本定义、内置函数

    一.深浅拷贝 import copy #浅拷贝 n1={'k1':'wu','k2':123,'k3':['carl',852]} n2=n1 n3=copy.copy(n1) print(id(n1 ...

  5. 拷贝,集合,函数,enumerate,内置函数

    1.拷贝 字符串和数字.赋值 id一样 import copy #提供拷贝功能 copy.copy() #原来的和现在的一起修改,不用修改时用浅copy,节省内存,复制最外层 copy.deepcop ...

  6. Kotlin函数与Lambda表达式深入

    Kotlin函数: 关于Kotlin函数在之前也一直在用,用fun来声明,回忆下: 下面再来整体对Kotlin的函数进行一个学习. 默认参数(default arguments): 先来定义一个函数: ...

  7. C++ 理解函数对象与lambda表达式

    参考<21天学通C++>第21与第22章节,对函数对象进行介绍,同时通过lambda表达式这一匿名函数对象的简洁方式加深对函数对象的理解.本篇博文的主要内容是: (1) 函数对象的概念: ...

  8. 匿名函数 lambda表达式(lambda expression)

    阅读g2log时,发现有两行代码居然看不懂. 1. auto bg_call =  [this, log_directory]() {return pimpl_->backgroundChang ...

  9. lambda函数、lambda表达式

    C++11 新特性:Lambda 表达式 豆子 2012年5月15日 C++ 10条评论 参考文章:https://blogs.oracle.com/pcarlini/entry/c_1x_tidbi ...

随机推荐

  1. 极光推送API

    https://github.com/jpush/jpush-api-ruby-client/blob/master/docs/Guides.md#%E6%9B%B4%E6%96%B0%E8%AE%B ...

  2. SSRF漏洞分析与利用

    转自:http://www.4o4notfound.org/index.php/archives/33/ 前言:总结了一些常见的姿势,以PHP为例,先上一张脑图,划√的是本文接下来实际操作的 0x01 ...

  3. [转]Red Hat Linux相关产品iso镜像下载【百度云】

    超强汇总!献上大佬链接:http://www.linuxfly.org/post/659/ 还有一些可用链接: 下面的直接复制到迅雷下载,链接是打不开的. RHEL 5.4 ISO下载http://r ...

  4. [Android] Android 用于异步加载 ContentProvider 中的内容的机制 -- Loader 机制 (LoaderManager + CursorLoader + LoaderManager.LoaderCallbacks)

    Android 用于异步加载 ContentProvider 中的内容的机制 -- Loader 机制 (LoaderManager + CursorLoader + LoaderManager.Lo ...

  5. 四、文件IO——内核数据结构和原子操作

    4.1 缓存 buff 说明 一般设置缓存 buff  的大小是由一定的规律的,就是根据磁盘块的大小来定. Linux下输入命令: df -k  查看磁盘 可以用命令查看下 /dev/sda1 磁盘的 ...

  6. 【转】const int *p和int * const p的区别(常量指针与指向常量的指针)

    [转]作者:xwdreamer   出处:http://www.cnblogs.com/xwdreamer 对于指针和常量,有以下三种形式都是正确的: const char * myPtr = &am ...

  7. java mongoTemplate的group统计

    @Service public class MongoCountServiceImpl implements MongoCountService { @Autowired private MongoT ...

  8. Python之进程 2 - multiprocessing模块

    ​ 我们已经了解了,运行中的程序就是一个进程.所有的进程都是通过它的父进程来创建的.因此,运行起来的python程序也是一个进程,那么我们也可以在程序中再创建进程.多个进程可以实现并发效果,也就是说, ...

  9. NEX 事件

    我正在上班突然看到这个事情差点没笑抽. 转自纯洁的微笑:原文在此:http://www.cnblogs.com/ityouknow/p/9247842.html#4010697 大家知道 VIVO 上 ...

  10. ORM映射和路由系统

    ORM映射: OBJECT ====> 对象 RELATION ===> 联系 MODEL ===> 数据模型 安装pyMysql 安装flask-sqlAchemy 导入: fro ...