今日大纲:

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

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. hdu3001Travelling

    参考了别人的代码   https://blog.csdn.net/u010372095/article/details/38474721 深感自己的弱小 这是tsp问题,和基本的tsp问题没什么大的区 ...

  2. mysql windows 5.7 安装版下载地址

    https://dev.mysql.com/downloads/windows/installer/5.7.html

  3. 一篇入门 -- Git

    一. Git 介绍 Git作为一款分布式的==版本控制==工具,作为一名程序员,是必须要掌握的. 最初由林纳斯·托瓦兹(Linus Torvalds)创作,于2005年以GPL发布.最初目的是为更好地 ...

  4. 带你入门Python爬虫,8个常用爬虫技巧盘点

    python作为一门高级编程语言,它的定位是优雅.明确和简单. 我学用python差不多一年时间了, 用得最多的还是各类爬虫脚本, 写过抓代理本机验证的脚本.写过论坛中自动登录自动发贴的脚本 写过自动 ...

  5. 【Spark调优】:结合业务场景,优选高性能算子

    聚合操作使用reduceByKey/aggregateByKey替代groupByKey 参见我的这篇博客说明 [Spark调优]:如果实在要shuffle,使用map侧预聚合的算子 内存充足前提下使 ...

  6. sql 语句的limit的用法

    SELECT * FROM table  LIMIT [offset,] rows | rows OFFSET offset   mysql> SELECT * FROM table LIMIT ...

  7. Linux - 常用网络操作

    001 - Linux CentOS网络配置 CentOS---网络配置详解 002 - Linux查看端口状态 检测本机8080端口状态:netstat –apn | grep 8080 检测192 ...

  8. Java 中的伪共享详解及解决方案

    1. 什么是伪共享 CPU 缓存系统中是以缓存行(cache line)为单位存储的.目前主流的 CPU Cache 的 Cache Line 大小都是 64 Bytes.在多线程情况下,如果需要修改 ...

  9. HoloLens开发手记 - HoloLens真机上手简评

    千呼万唤始出来,终于今天拿到了HoloLens真机. 使用体验 使用自带的应用录制了一段使用视频,如下 设备概览 包装盒 本体 试戴 实际效果 GalaxyExplorer试玩 全息图像贴到现实场景表 ...

  10. mysql之数据分区

    一:概述  通过把表分成多几区间,每个区间存储符合特定表达式的数据(即在我们创建分区表时指定每个分区存储的条件例如:PARTITION p0 VALUES LESS THAN (100) 即p0区间存 ...