python笔记01(详情请看廖雪峰的官方网站)
python 在调用函数的时候,
如果传入的参数数量不对,
如果传入的参数类型不对
会报TypeError的错误,并且Python会明确提示参数错误原因。
hex()内置函数会把一个整数转换成十六进制表示的字符串。
’定义一个函数要使用def语句。依次写出函数名,括号,括号中的参数和冒号:”
调用函数时,参数不对,会自检。抛出TypeError,参数类型不对,无法检查,修改my_abs,对类型做检查。只允许整数和浮点类型。
def my_abs():
if not isinstance(x,(int,float)):
raise TypeError('bad operand type')
if x>=0:
return x
else:
return -x
import math
def move(x,y,step,angle=0):
nx=x+step*math.cos(angle)
ny=y-step*math.sin(angle)
return nx,ny
>>x,y=move(100,100,60,math.pi / 6)
>>print(x,y)
同时获得返回值。但是这只是一个假象,Python函数返回的任然是单一值:
r=move(100,100,60,math.pi /6 )
print(r)
返回的值是一个tuple ,在语法上tuple可以省略括号,多个变量可以同时接受tuple.
type("asdhu") 返回str.测试类型。
Class myClass():
pass
test = myClass()
isinstance(test,myClass) 返回true isinstance的测试范围更广 。
对于关键字参数,函数的调用者可以传入任意不受限制的关键字参数,至于到底传入了哪些,需要kw检查。
def person(name,age,**kw):
if 'city' in kw:
pass
if 'job' in kw:
pass
print('name',name,'age',age','other',kw)
不可变参数
def add_end(L=None):
if L=None:
L=[]
L.append('END')
return L
把函数的参数该为可变参数
def calc(*numbers):
sum=0
for i in numbers:
sum=sum+i**2
return sum
nums=[1,2,3]
calc=(*nums)
如果要限制关键字的名字,
def person(name,age,*,city,job):
print(name,age,city,job)
与**kw不同。命名关键字参数需要一个特殊分隔符* , *后面的参数呗视为命名关键字参数。
调用方式:
>>>person(‘JACK’,24,city='beijing',job='engineer')
如果函数定义中已经有了一个课表参数,后面跟着的命名关键字参数就不在需要一个特殊分隔符*、
def person(name,age,*args,city,job):
print(name,age,args,city,job)
def fii(name,age,city='shanghai',*args,*,d,**kw) 正确的定义函数的参数的顺序,必选的位置参数,默认,可变参数,命名关键字参数,关键字参数。
对于任意函数,都可以通过类似function(*args, **kw)
的形式调用它,无论它的参数是如何定义的。
def fact(n):
if n==1:
return 1
return n*fact(n-1)
以上递归函数的作用是返回1到n的阶层, 但是存在一个严重的问题 ,传入较大的数时,栈溢出,调用一个函数,栈就增加一层,函数返回,栈就减少一层。
解决递归栈溢出 : 尾递归优化。(无论递归本身调用多少次,都不会出现栈溢出)
def fact(n):
return fact_iter(n,1)
def fact_iter(num,product):
if num==1:
return product
return fact_iter(num-1,num*product)
练习:
汉诺塔的移动。
请编写move(n,a,b,c)的函数,它接受参数n,表示3个柱子 A,,B,C中第一个柱子A的盘子数量,然后打印出把所有盘子从A借助B移动到C的方法。
def move(n,a,b,c):
if n==1:
return (a," ->",c)
else:
move(n-1,a,c,b)
move(1,a,b,c)
move(n-1,b,a,c)
利用切片操作,实现一个trim()函数,去掉字符串首尾空格。注意不要用strip()方法
#_*_ coding:utf-8 _*_
def trim(s):
if s[:1] !=' ' and s[:-1] !=' ':
return s
elif s[:1]==' ':
return trim(s[1:])
else:
return trim(s[:-1])
请用迭代查找一个list中最小和最大值。并返回一个tuple:
# -*- coding:utf-8 -*-
def findMinAndMax(L):
if L!=[]:
min=l[0]
max=l[0]
for i in L:
if max<i:
max=i
if min>i:
min=i
return (min,max)
else:
return(None,None)
列表生成式:
>>>[x*x for x in range(1,11)]
[1.4.9.16.25.36.49.64.81.100]
>>>[x*x for x in range(1,11) if x%2 == 0 ]
[4,16,36,64,100] 偶数的平方。
写一个功能、。 列出当前目录下的所有文件和目录名,可以通过一行代码实现、
>>>import os
>>>[d for d in os.listdir('.')]
把一个list的所有的字符串变成小写:
>>> L=['Hello','World','IBM','Apple']
>>>[s.lower() for s in L]
测试可迭代对象:>>>isinstance([],Iterable)
>>>isinstance('2124',Iterable)
高级特性之生成器:
创建生成器的方法 :
① 把列表生成式的[ ]改成()即可。、
g=(x*x for x in range(10)),通过next(g)返回generator的下一个返回值。一般都用for循环来迭代
generator保存的是算法。计算到最后一个元素抛出stopIteration错误。
② def fib(max):
n,a,b=0,0,1
while n<max:
yield b
a,b=b,a+b
return 'done' ####斐波那契数列 后一个数是前两个数的和
python笔记01(详情请看廖雪峰的官方网站)的更多相关文章
- python 廖雪峰的官方网站
https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014316119884678 ...
- 使用@property - 廖雪峰的官方网站
使用@property 阅读: 20616 在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9 ...
- github教程--廖雪峰的官方网站
http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000
- Python自学笔记-字符串编码(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 1.理解变 ...
- Python自学笔记-sorted()函数(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 排序算法 排序 ...
- Python自学笔记-lambda函数(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 匿名函数 通过 ...
- Python自学笔记-filter()函数(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. Python内 ...
- Python自学笔记-列表生成式(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 列表生成式 列 ...
- Python自学笔记-关于切片(来自廖雪峰的官网Python3)
感觉廖雪峰的官网http://www.liaoxuefeng.com/里面的教程不错,所以学习一下,把需要复习的摘抄一下. 以下内容主要为了自己复习用,详细内容请登录廖雪峰的官网查看. 切片 L[0: ...
随机推荐
- poj 1564 Sum It Up(dfs)
Sum It Up Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7191 Accepted: 3745 Descrip ...
- 安装SQL2005数据库服务时报错处理方法
运行一个脚本,以管理员身份运行: net stop winmgmt c: cd %systemroot%/system32/wbem rd /S /Q repository regsvr32 /s % ...
- C++ STL(标准模板库)
一.STL简介 STL(Standard Template Library,标准模板库)是惠普实验室开发的,在被引入C++之前该技术就已经存在了很长的一段时间. STL的代码从广义上讲分为三类:alg ...
- Django【第24篇】:JS实现的ajax和同源策略
JS实现的ajax和同源策略 一.回顾jQuery实现的ajax 首先说一下ajax的优缺点 优点: AJAX使用Javascript技术向服务器发送异步请求: AJAX无须刷新整个页面: 因为服务器 ...
- pandas、matplotlib、Numpy模块的简单学习
目录 一.pandas模块 二.matplotlib模块 1.条形图 2. 直方图 3.折线图 4.散点图+直线图 三.numpy 一.pandas模块 pandas是BSD许可的开源库,为Pytho ...
- LeetCode--006--Z 字形变换(python)
将一个给定字符串根据给定的行数,以从上往下.从左到右进行 Z 字形排列. 比如输入字符串为 "LEETCODEISHIRING" 行数为 3 时,排列如下: 之后,你的输出需要从左 ...
- LeetCode--096--不同的二叉搜索树(python)
我的思路比较low直接看官方题解吧... class Solution: def numTrees(self, n: int) -> int: G = [0] * (n+1) G[0],G[1] ...
- UI Recorder安装与使用
现在的互联网公司,普遍在尝试并执行敏捷开发模式,那么必然要涉及到频繁的更新迭代,在每次更新迭代时,老功能的回归成为了老大难.当系统日益复杂,涉及到的回归点逐渐增多,UI自动化测试即使成本在大,也需要提 ...
- iOS Core Image-----十行代码实现微信朋友圈模糊效果
昨天下午微信的朋友圈着实火了一把,在这之后好多程序员都通过抓包工具看到了原图,但是我却在想,网上说是在移动前端做到的那是怎么做到的呢,经过一些学习,终于掌握了一些Core Image的知识,做出了相应 ...
- 【bzoj2733】[HNOI2012]永无乡
题目描述: 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到 ...