小甲鱼Python笔记(上)

基于Python 3.4.3

一 二 三 四  基础

print 三版必须加括号,二版不用加

alt + n :上一条语句

alt + p :下一条语句

打印三条hello

没有大括号,用缩进来表示

BIF 内建函数

使用变量前要先对其赋值

字母可以使大小写,但是大小写是不同的

字符串可以用单引号或者是双引号

原始字符串:在字符串前面加上r,就不用加转义字符了

长字符串,多行,用三引号字符串

条件分支

if 条件:

  条件为真执行的操作

else:

  条件为假执行的操作

猜数字:

 1 print("这是一个猜数字游戏")
 2 import random
 3 secret = random.randint(1,10)
 4 temp = input("请输入1-10数字:")
 5 guess = int(temp)
 6 while guess != secret:
 7     if secret > guess:
 8         temp = input("小了
")
 9         guess = int(temp)
10     else:
11         temp = input("大了
")
12         guess = int(temp)
13 print("恭喜答案正确")

五 变量类型

整型、浮点、e记法、布尔类型(布尔类型首字母大写,True,False)

不要把str当作变量名,str()是个BIF

获得关于类型的BIF type()

python更建议用isinstance()判断类型,返回值是bool

六 操作符

+  -  *  % **  //

可以写成 a = b = c = d = 10

幂运算的优先级比起左侧操作符高,比右侧操作符低

>>> -3 ** 2
-9

>>> 3 ** -2
0.1111111111111111

七 八 九 分支和循环

 1 score = int(input("请输入一个分数:"))
 2 if 90 <= score <=100:
 3     print("A")
 4 elif 80 <= score <90:
 5     print("B")
 6 elif 70 <= score <80:
 7     print("C")
 8 elif 60 <= score <70:
 9     print("D")
10 else:
11     print("E")

三元操作符

语法: x if 条件 else y

eg:

x = 6
y = 5
small = x if x<y else y
print(small)

结果:

5

 for循环

1 s = "favourite"
2 for i in s:
3     print(i,end = " ")

列表

member = ["a","ab","abc","abcd","abcde","abcdefg"]
for i in member:
    print(i,len(i))

range()

range([strat,][stop][,step=1])

经常与for循环使用,这个BIF有三个参数,其中中括号括起来的的两个表示这两个参数是可选的。

step=1表示第三个参数的值默认值是1

range这个bif的作用是生成一个从start参数的值开始到stop结束的序列

break

 1 print("这是一个猜数字游戏")
 2 import random
 3 secret = random.randint(1,10)
 4 guess = int(input("请输入1-10数字:"))
 5 while True:
 6     if guess == secret:
 7         break
 8     else:
 9         guess = int(input("输入错误,请重新输入"))
10 print("恭喜答案正确")

十 十一 十二  列表

查看列表方法:

列表可以是混合类型的

列表可以使空的

Noen是Python的一个内建值

.append()表尾追加一个值

.extend()在表尾追加一个列表

.insert(位置,元素)

.index(元素)  获取元素位置

可以加上搜索范围.index(元素,其实位置,终止位置)

.remove(元素)  删除元素

del 序列[位置]

.pop(元素位置)  默认是最后一个

.count(元素)  计算元素个数

.reverse()  元素翻转

.sort()  排序

改变原始列表

倒序可以:

列表分片

第一个索引是提取第一个元素的编号,而最后的索引则是分片之后剩余部分的第一个元素的编号

也就是第一个索引元素包含在分片之内,而第二个则不包含在分片之内

列表复制一定要用这种方法

列表能用的元算 +(两个序列必须类型一致) *

成员资格 in

访问列表中的列表,类似于二维数组

十三 元组

元组不可修改,是由括号和逗号定义的

修改元祖只能给其重新赋值:

十四  字符串方法

字符串和元组一样都是都是不可改变的 

几个常用的方法:

.find()

find方法可以在一个较长的字符串中查找子串。返回字串所在位置最左端的索引,如果没有则返回-1。这个方法可以接收可选的起始点或结束点参数

.lower()

返回字符串的小写字母版,主要用于编写不区分大小写的代码

.split()

分割字符串成序列,如果不提供任何分割符,则把所有空格当作分隔符

.joint()

split的逆方法,分隔符.join(字符串)

.replace()

返回字符串的所有匹配项被替换后的字符串,.replace(“被替换”,“替换”)

.translate()

translate方法只处理单个字符,优势在于可以同时进行多个字符替换,使用translate转换之前,需要先完成一张转换表

注意import的是string,但是用的时候是str

十五  字符串格式化

 .format() 位置输出

% 格式化操作符

用#填充数字进制格式

控制字段宽度精度

总结:

十六  序列

列表、元组和字符串放在一块儿来讲解是有道理的,我们发现Ta们之间有很多共同点:

1. 都可以通过索引得到每一个元素

2. 默认索引值总是从0开始(当然灵活的Python还支持负数索引)

3. 可以通过分片的方法得到一个范围内的元素的集合

4. 有很多共同的操作符(重复操作符、拼接操作符、成员关系操作符)

所以我们把他们叁统称为:序列

序列常用的方法

list(iterable) 把一个可迭代对象转换为列表

tuple([iterable]) 把一个可迭代对象转换为元组

str(obj) 把obj对象转换为字符串

len(sub) 返回sub的长度

max() 返回序列或者参数集合中的最大值

min() 返回序列或者参数集合中的最小值

sum(iterable[, start=0]) 返回序列iterable和可选参数start的总和

sorted(iterable, key=None, reverse=False) 返回一个排序的列表,使用方法跟列表的内建函数(list.sort())一致,注意,这个sorted()后边有“ed”哦。


reversed(sequence) 返回逆向迭代序列的值,一样道理,跟列表的内建函数(list.reverse())一致,注意,这个reversed()后边也多了个“d”哦。


enumerate(iterable) 生成由每个元素的index值和item值组成的元组


zip(iter1 [,iter2 […]]) 返回由各个参数的序列组成的元组

 二十五 二十六  字典

字典是Python语言中唯一的映射类型。

映射类型对象里哈希值(键,key)和指向的对象(值,value)是一对多的的关系,通常被认为是可变的哈希表。

字典对象是可变的,它是一个容器类型,能存储任意个数的Python对象,其中也可包括其他容器类型。

字典类型与序列类型的区别:

1.存取和访问数据的方式不同。

2.序列类型只用数字类型的键(从序列的开始按数值顺序索引);

3.映射类型可以用其他对象类型作键(如:数字、字符串、元祖,一般用字符串作键),和序列类型的键不同,映射类型的键直

4.接或间接地和存储数据值相关联。

5.映射类型中的数据是无序排列的。这和序列类型是不一样的,序列类型是以数值序排列的。

6.映射类型用键直接“映射”到值。

字典的创建

特点:
1、键与值用冒号“:”分开;
2、项与项用逗号“,”分开;
3、字典中的键必须是唯一的,而值可以不唯一。

使用工厂函数dict()创建字典:

注意括号的个数,因为dict()只接受一个参数,所以用()把键值对包括

键值对的增加与删除

字典的方法

1、adict.keys() 返回一个包含字典所有KEY的列表;

2、adict.values() 返回一个包含字典所有value的列表;

3、adict.items() 返回一个包含所有(键,值)元祖的列表;

4、adict.clear() 删除字典中的所有项或元素;

5、adict.copy() 返回一个字典浅拷贝的副本;

直接赋值并没有创建新的内存空间

6、adict.fromkeys(seq, val=None) 创建并返回一个新字典,以seq中的元素做该字典的键,val做该字典中所有键对应的初始值(默认为None);

初始化一个空字典:

注意,仅仅是返回一个新字典,并不能改变旧字典,要想改变必须用a = a.fromkeys

7、adict.get(key, default = None) 返回字典中key对应的值,若key不存在字典中,则返回default的值(default默认为None);

一般来说如果试图访问字典中不存在的项时会出错,而用get就不会

8、  in 、 not in;

9、adict.iteritems()、adict.iterkeys()、adict.itervalues() 与它们对应的非迭代方法一样,不同的是它们返回一个迭代子,而不是一个列表;

10、adict.pop(key[,default]) 和get方法相似。如果字典中存在key,删除并返回key对应的vuale;如果key不存在,且没有给出default的值,则引发keyerror异常;

11、adict.setdefault(key, default=None) 和set()方法相似,但如果字典中不存在Key键,由 adict[key] = default 为它赋值;

12、adict.update(bdict) 将字典bdict的键值对添加到字典adict中。

字典中的键,值,键值对用  .keys()  .values()  .items()表示 

二十七 集合

集合不会出现重复元素,用{}标记,set()函数将其他容器类型转变为集合,有.add()和.remove()方法,当用frozenset()函数定义一个集合时,这个集合不可改变

函数

裴波那切的例子:

利用上列表的-1 -2来表示后两个元素的方法很巧妙

1 def fibs(num):
2     a = [0,1]
3     for i in range(num-2):
4         a.append(a[-1] + a[-2])
5     return a
6 
7 num = int(input("How many Fibonacci nubmers do you want:"))
8 print(fibs(num))

 执行结果:

另一个方法 :

1 def fib(num):
2    n,a,b = 0,0,1
3    while(n < num):
4       print(b)
5       a,b = b,a+b
6       n += 1
7 num = int(input("How many Fibonacci nubmers do you want:"))
8 fib(num)

在函数里面修改全局变量的值需要加上globle,否则将在函数内创建另一个同名的局部变量

1 num = 3
2 def chcange_globle():
3     global num
4     num = 6
5 print(num)

注意是globle不是global(前者是名次,后者是形容词)

关键字参数和默认参数

在函数调用过程中用参数名提供的参数是关键字参数

在函数定义过程中用参数名提供的参数是默认参数

1 def who_words(name = '王尼玛',words = '来来来'):
2     print(name,words)
3 who_words()#使用默认参数
4 who_words('丁尼玛')
5 who_words(words = '我草',name = '赵尼玛')#使用关键字参数

收集函数

*params

1 def print_params(*params):
2     print("the num of params is :",len(params))
3     print("the third param is :",params[2])
4     print(params)
5 print_params('a','b','c','d','e')

若参数中还有其他参数需要用关键字参数指出,否则会被认成收集参数,导致程序出错

1 def print_params(*params,name,age):
2     print("the num of params is :",len(params))
3     print(params)
4     print(name,age)
5 print_params('a','b',name = '王叔叔',age = '22')

**params

返回字典

1 def fun(**params):
2     print(params)
3 fun(x=1,y=2)

嵌套

一个函数放在另一个函数里面,就是嵌套

闭包:如果在一个内部函数,对在外部作用域引用的变量,内部函数就叫做闭包

1 def fun1(x):
2     def fun2(y):
3         return x*y
4     return fun2()

两种实现方式:

递归

 1 def han(n,x,y,z):
 2     "将n层汉诺塔从x移动到z上"
 3     if n == 1:
 4         print(x,'-->',z)
 5     else:
 6         han(n-1,x,z,y)
 7         print(x,'-->',z)
 8         han(n-1,y,x,z)
 9 n = int(input("input n:"))
10 han(n,'X','Y','Z')

 执行结果:

 

如果在函数开头写下字符串,它会作为函数的一部分进行存储,这称为文档字符串。调用方法:函数名.__doc__  (注意是双下划线)

函数式编程

某些语言使用函数就可以完成所有的事(Lisp,Erlang,F#),没有变量,只有输入输出和函数(以上为自己理解)

Python提供函数式编程思想的函数有:lambda、map、filter、reduce

lambda:

map:将序列中的元素全部传递给一个函数

map(function, sequence[, sequence, ...]) -> list

通过定义可以看到,这个函数的第一个参数是一个函数,剩下的参数是一个或多个序列,返回值是一个集合。

function可以理解为是一个一对一或多对一函数,map的作用是以参数序列中的每一个元素调用function函数,返回包含每次function函数返回值的list。

filter:过滤出为真值的列表

filter(function or None, sequence) -> list, tuple, or string

function是一个谓词函数,接受一个参数,返回布尔值True或False。

filter函数会对序列参数sequence中的每个元素调用function函数,最后返回的结果包含调用结果为True的元素。

求奇数:

原文地址:https://www.cnblogs.com/raichen/p/4759691.html