今日大纲:

. 函数的初识
. 函数的返回值
. 函数的参数

1. 函数的初识


统计字符串s的总个数(不能用len)
s='fkahfkahofijalkfkadhfkjadhf'
count =
for i in s:
count +=
print(count)
统计列表lis的总个数(不能用len)
lis = [, , , , , , , , ]
count =
for i in lis:
count +=
print(count)
def:关键字;函数名:定义与变量定义一样
def my_len():
函数体
def my_len(lis):
count =
for i in lis:
count +=
print(count)
my_len([, , , , , , , , ]) 执行函数:函数名()
函数的优点:减少代码的重复率;增强代码的阅读性

函数到底是什么?函数最主要的目的:封装一个功能
s='fkahfkahofijalkfkadhfkjadhf'
print(len(s))
. 函数的返回值:return
. 函数中如果遇到return,则直接结束函数
. 给函数的执行者返回值。
- return: None
- return 单个值: 原封不动的返回
- return 多个值: 返回一个元组, 所有的值作为元组的每一个元素
工作中,函数中尽量不要出现print()
def func1():
print()
print()
return
print()
func1() 整体是函数的执行者 def func1():
'''返回多个值'''
a =
b =
c = a + b
d = 'alex'
e = [, , ]
return c, d, e
ret = func1()
print(ret, type(ret))
结果:(返回一个元组)
(, 'alex', [, , ]) <class 'tuple'> def my_len(s):
count =
for i in s:
count +=
return count
print(my_len('fjklashfklah'))

3. 函数的传参


. 实参
- 位置参数:必须要遵循按照顺序,一一对应
- 关键字参数:可以不按照顺序,但是必须一一对应
- 混合参数:关键字参数一定要在位置参数后面

. 形参
- 位置参数:按照顺序,一一对应
- 默认参数
def my_len(argv):   形参:形式参数
count =
for i in argv:
count +=
return count
print(my_len('fjklashfklah')) 函数的执行者(实参):实际的参数
- 实参
位置参数: 必须要遵循按照顺序,一一对应
def func1(x, y):
print(x, y)
func1(, )
2个函数:
- 返回两个数的和并且返回
- 返回两个数的最大值
.
def my_sum(x, y):
return x + y
print(my_sum(, )) .
def my_max(a, b):
if a > b:
return a
else:
return b
print(my_max(, ))
三元运算:只针对于简单的if else这样的结构,才可以使用
ret = x if x > y else y
def my_max(a, b):
return a if a > b else b
print(my_max(, ))
关键字传参: 可以不按照顺序,但是必须一一对应
def func1(x, y):
return x + y
func1(y = , x = )
混合传参:关键字参数一定要在位置参数后面
def func1(a, b, n, x, y):
return x + y name = 'alex'
func1(, , name, y = , x = )
形参角度:
位置参数:按照顺序,一一对应
默认参数:给其传值,将原来的默认参数覆盖掉;不传值,不报错,使用默认值
应用场景:不经常改变的参数,但是一直在用
def func1(x, y, z):
print(x, y, z)
func1(, , ) def func1(x, y, z = )
print(x, y, z)
func1(, )
func1(, , ) def name_list(n1, s1 = '男'):
with open('name_list', encoding='utf-8', mode='a') as f1:
f1.writer('{}|{}\n'.format(n1, s1))
while :
name, sex = input('请输入姓名,性别:以,隔开').strip().replace(',', ',').split(',')
if name.upper() == 'Q':break
if sex.strip():
name_list(name, sex)
else:
name_list(name)
默认参数的陷阱(面试题必考)
默认参数若是可变的数据类型,他始终使用的是一个

def func1(x, l1 = []):
l1.append(x)
return l1
ret = func1()
print(ret, id(ret))
ret1 = func1()
print(ret1, id(ret1))
结果:
[]
[, ]

Python全栈学习_day009知识点的更多相关文章

  1. Python全栈学习_day002知识点

    今日大纲: . while循环 . 格式化输出 . 运算符 . 编码初识 1. while循环 - while 无限循环: while True: # 死循环 print('大悲咒') print(' ...

  2. Python全栈学习_day003知识点

    今日大纲: . 基础数据类型 总览 . int . bool . str . for循环 1. 基础数据类型 总览 int: 用于计算,计数等 str:'这些内容',用户少量数据的存储,便于操作 bo ...

  3. Python全栈学习_day001知识点

    今日大纲: . 变量. ***** . 常量.** . 注释.*** . 基础数据类型初识(int,str,bool). ***** . 用户输入 input ***** . 流程控制语句if. ** ...

  4. Python全栈学习_day005知识点

    今日内容大纲: . 字典的增删改查以及其他操作 . 字典的嵌套 . 字典的增删改查以及其他操作 , 'sex': '男'}, 'name_list': ['无双', 'alex', 'BlameK'] ...

  5. python全栈学习路线

    python全栈学习路线-查询笔记 查询目录 一,硬件                                                                    十一,数据 ...

  6. python全栈学习--day4

    列表 说明:列表是python中的基础数据类型之一,它是以[]括起来,每个元素以逗号隔开,而且他里面可以存放各种数据类型比如:   1 li = ['alex',123,Ture,(1,2,3,'wu ...

  7. python全栈学习--day3

    一.基础数据类型 基础数据类型,有7种类型,存在即合理. 1.int 整数 主要是做运算的 .比如加减乘除,幂,取余  + - * / ** %...2.bool 布尔值 判断真假以及作为条件变量3. ...

  8. python全栈学习--day2

    一.in的使用 说明:in有相当多的用处,比如判断,循环for 等. 实例一:in 操作符用于判断关键字是否存在于变量中 s = '男人john' print('男孩' in s) print('男孩 ...

  9. python全栈学习--day1

      计算机基础 CPU:中央处理器 内存:4GB,8GB,临时处理事务的地方,供给CPU数据. 硬盘:相当于电脑的数据库,存储着大量的数据,文件,电影等. 操作系统:执行者,支配所有关系 window ...

随机推荐

  1. Shell 中字符串变量的赋值注意点

    1. 变量赋值 语法:var="saaaa" PS: 等号两边不能有空格 2. 脚本示例如下: #!/bin/sh # Get bug activity info # usage ...

  2. 2018.09.22 上海大学技术分享 - An Introduction To Go Programming Language

    老实说笔者学习 Go 的时间并不长,积淀也不深厚,这次因缘巧合,同组的同事以前是上海大学的开源社区推动者之一,同时我们也抱着部分宣传公司和技术分享的意图,更进一步的,也是对所学做一个总结,所以拟定了这 ...

  3. Vmware Vtop基本使用

      俗话说:"最了解孩子的莫过于亲妈",算了编不下去了,简而言之就是我们想知道虚机的详情可以通过Vmware Vtop登录宿主机进行查看,直接上干货.   有这些信息我们可以从Vt ...

  4. 技术文档生成工具:appledoc

    做项目一般都会要求写技术文档,特别是提供SDK或者基础组件的.如果手写这类技术文档的话,工作量比编写代码也少不了多少.比如 Java 语言本身就自带 javadoc 命令,可以从源码中抽取文档.本篇我 ...

  5. 深圳scala-meetup-20180902(3)- Using heterogeneous Monads in for-comprehension with Monad Transformer

    scala中的Option类型是个很好用的数据结构,用None来替代java的null可以大大降低代码的复杂性,它还是一个更容易解释的状态表达形式,比如在读取数据时我们用Some(Row)来代表读取的 ...

  6. weblogic安装及配置

    WebLogic是用于开发.集成.部署和管理大型分布式Web应用.网络应用和数据库应用的Java应用服务器. 1.安装Weblogic:(1)点击Next按钮:(2) 选择Custom后点击Next按 ...

  7. Unicode 字符串排序规则(一):如何确定单个字符的顺序

    一.一个具体的例子引发的问题 当今是国际化的时代,多种语言可能同时显示在屏幕上.比如一个人可能喜欢听华语歌.英文歌.韩文歌和日语歌,又比如他的联系人中有中国人.英国人.日本人.韩国人以及有英文名字的中 ...

  8. java项目使用mvn打包时,出现数据库连接错误

    原因: maven在install的时候会默认去执行test包下的test示例,导致打包失败,只需要把测试注释掉就可以了包括类上的注解,或者在install的时候跳过测试,install -Dmave ...

  9. scrapy爬虫--苏宁图书

    实现业务逻辑如下: 1. 创建scrapy项目,并生成 爬虫2. 在suning.py中实现Schedul 和 Spider业务逻辑3. 修改start_urls为正确的初始请求地址4. 构造pars ...

  10. 如何用python爬取两个span之间的内容

    Python用做数据处理还是相当不错的,如果你想要做爬虫,Python是很好的选择,它有很多已经写好的类包,只要调用,即可完成很多复杂的功能,此文中所有的功能都是基于BeautifulSoup这个包. ...