一、向函数中传递任意数量的实参

有时候,你预先不知道函数需要接受多少个实参,Python中函数可以收集任意数量的实参。

栗子:来看一个打印好友列表功能的函数,它需要接收任意数量的好友名。如下:

 def print_friends(*friends):
"""打印好友名"""
print(friends) print_friends('jhson')
print_friends('joker','jack','nacy')

console:

解释:上面的函数中只有一个形参  *friends,但不管调用语句提供多少实参,这个形参都能将它们统统收入囊中,

形参名 *friends 中的星号让Python创建一个名为friends的空元组,并将收到的所有值都放入这个元组中。函数体内

的print 语句通过生成输出来证明Python能够处理使用一个值调用函数的情形,也能处理使用三个值调用函数的情形。

它以类似的方式处理不同的调用,需要注意的是,函数将收到的值放入元组中,即使只有一个值也是如此。

我们改进下,用循环打印这个元组中的值:

 def print_friends(*friends):
"""打印好友名"""
print("\nmy friends :")
for friend in friends:
print(friend) print_friends('jhson')
print_friends('joker','jack','nacy')

console:

不管收到一个值还是三个值,这个函数都能妥善处理,其实不管函数实参是多少个,这种语法都管用。

二、使用任意数量的关键字实参

有时候,需要接收任意数量的实参,但预先不知道传递给函数的会是什么样的信息。在这种情况下,可将函数编写成能够

接收任意数量的键-值对,调用语句提供了多少就接收多少。

栗子:你知道你将收到有关用户的信息,但不确定是什么样的信息,如下:

 def user_profile(first,last,**user_info):
"""创建一个字典,其中包含我们知道有关用户的一切"""
profile={}
profile['first_name'] = first
profile['last_name'] = last
for key ,value in user_info.items():
profile[key] = value
return profile user_profile = user_profile('joker','pan',sex='male',country='China')
print(user_profile)

console:

解释:函数user_profile() 的定义要求提供名和姓,同时允许用户根据需要提供任意数量的名称-值对。形参中的**user_info中的两个星号,

让Python创建一个名为user_info的字典,并将收到的所有名称-值对都封装到这个字典中。在这个函数中像访问其他字典那样访问user_info

中的名称-值对。在这里不仅将名和姓传入函数,还将性别和所属国家也传入,该函数也能正确处理并返回包含用户信息的字典。

传递参数的方式有很多种,牢记使用最简单的方法来完成任务就好了。

世界很公平,比你忙的人赚的比你多,比你闲的人你赚的比他少。

Python中的函数(5)的更多相关文章

  1. Python中split()函数的用法及实际使用示例

    Python中split()函数,通常用于将字符串切片并转换为列表. 一.函数说明: split():语法:str.split(str="",num=string.count(st ...

  2. Python中利用函数装饰器实现备忘功能

    Python中利用函数装饰器实现备忘功能 这篇文章主要介绍了Python中利用函数装饰器实现备忘功能,同时还降到了利用装饰器来检查函数的递归.确保参数传递的正确,需要的朋友可以参考下   " ...

  3. python中range()函数的用法

    python中range()函数可创建一个整数列表,一般用在for循环中. range()函数语法: range(start,stop[,step]) 参数说明: star: 计数从star开始.默认 ...

  4. Python 中的函数

    学了 Python 中的数据类型,语句,接下来就来说一下 Python 中的函数,函数是结构化编程的核心.我们使用函数可以增加程序的可读性.自定义函数时使用关键字def 函数由多条语句组成.在定义函数 ...

  5. python中format函数

    python中format函数用于字符串的格式化 通过关键字 1 print('{名字}今天{动作}'.format(名字='陈某某',动作='拍视频'))#通过关键字 2 grade = {'nam ...

  6. Python中readline()函数 去除换行符

    从Python中readline()函数读取的一行内容中含有换行符\n,很多时候我们需要处理不含有换行符的字符串,此时就要去掉换行符\n. 方法是使用strip()函数. 例子如下: f = open ...

  7. Python中int()函数的用法浅析

      int()是Python的一个内部函数 Python系统帮助里面是这么说的 >>> help(int)  Help on class int in module __builti ...

  8. 【313】python 中 print 函数用法总结

    参考:python 中 print 函数用法总结 参考:Python print() 函数(菜鸟教程) 参考:Python 3 print 函数用法总结 目录: 字符串和数值类型 变量 格式化输出 p ...

  9. python中filter函数

    python中filter()函数   filter()函数是 Python 内置的另一个有用的高阶函数,filter()函数接收一个函数 f 和一个list,这个函数 f 的作用是对每个元素进行判断 ...

  10. Python中print()函数不换行的方法

    一.让print()函数不换行 在Python中,print()函数默认是换行的.但是,在很多情况下,我们需要不换行的输出(比如在算法竞赛中).那么,在Python中如何做到这一点呢? 其实很简单.只 ...

随机推荐

  1. (数位DP)51NOD 1042 数字0-9的数量

    给出一段区间a-b,统计这个区间内0-9出现的次数. 比如 10-19,1出现11次(10,11,12,13,14,15,16,17,18,19,其中11包括2个1),其余数字各出现1次.   输入 ...

  2. 153 Find Minimum in Rotated Sorted Array 旋转数组的最小值

    假设一个按照升序排列的有序数组从某未知的位置旋转.(比如 0 1 2 4 5 6 7 可能变成 4 5 6 7 0 1 2).找到其中最小的元素.你可以假设数组中不存在重复的元素.详见:https:/ ...

  3. NTP服务简介

    定义:NTP全称为Network Time Protocol,即网络时间协议.是用来使计算机时间同步的一种协议.它可以使计算机对服务器或时钟源做同步,可以提供高精度的时间校正(LAN 上与标准时间小于 ...

  4. logback日志异步打印

    最近碰到一个问题:客户的服务器程序偶尔出现请求响应过慢的情况,通过查看日志发现RSA验证签名的代码执行超过20秒,而正常情况下只需要16毫秒. RSA证书是服务器启动就加载好的,不存在读文件慢的问题. ...

  5. pageHelper分页插件失效问题

    在bootstrap中引用pageHelper进行页面分页<dependency><groupId>com.github.pagehelper</groupId>& ...

  6. CF779C(round 402 div.2 C) Dishonest Sellers

    题意: Igor found out discounts in a shop and decided to buy n items. Discounts at the store will last ...

  7. SQL Server 2008还原数据库的具体方法

    俗话说“好记性不如烂笔头”,在相隔较长的时间段内,每次还原客户的数据库都记不清完全的步骤,为此mark一下. SQL Server 2008一般默认备份的文件格式是bak,即后缀名为.bak.bak文 ...

  8. Backbone.js之Todo源码浅析

    相信每个接触了解过backbone的人都知道todo,网上的关于它的分析教程也都分析乱了.但是,知识只有自己学习领悟才是自己的,话不多说,正文开始. 在分析todo的源码之前,首先我们要知道todo具 ...

  9. 字符串循环右移-c语言

    一个长度为len的字符串,对其循环右移n位 [期望]char str[] = "abcdefg";右移3次后,变成"efgabcd" [思路] 思路1. 如果用 ...

  10. 如何用sql server数据库恢复.bak数据库备份

    @hcy(黄灿奕) 之前有两次都恢复不了,折腾了很长时间,这一次碰到这样的问题,居然又忘了,又捣鼓了很长时间,现在记下来 1.右击SQL Server 2008实例下的“数据库”文件夹.就是与安全性. ...