Open yingwinwin opened 4 years ago
L = ['Michael', 'Sarah', 'Tracy', 'Bob', 'Jack']
# 取出前三个变量,不用循环 下标为0,1,2的元素
print(L[:3]) # ['Michael', 'Sarah', 'Tracy']
# 取出从指定位置的元素
print(L[1:3]) # ['Sarah', 'Tracy']
# 支持负数
print(L[-2:]) #['Bob', 'Jack']
print(L[-2:-1]) #['Bob']
L = list(range(100)) # 0-99
# 取出前十个数
print(L[:10]) # [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
# 后十个数
print(L[-10:]) # [90, 91, 92, 93, 94, 95, 96, 97, 98, 99]
# 11 - 20 个数
print(L[10:20]) # [10, 11, 12, 13, 14, 15, 16, 17, 18, 19]
# 前10个数,每两个取一个
print(L[:10:2]) # [0, 2, 4, 6, 8]
# 所有数每5个取一个
print(L[::5]) # [0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95]
# 取出所有数
print(L[:])
# 取出tuple的前三项
print((1,2,3,4,5)[:3]) # (1, 2, 3)
# 取出字符串的前三项
print('ABCDEFG'[:3]) # ABC
# 循环 dict (默认循环key)
d = {'a': 1, 'b': 2, 'c': 3}
for key in d:
print(key)
# a b c
# 循环 dict的 value
for value in d.values():
print(value)
# 1 2 3
# 同时循环 dict 的 key 和 value
for k, v in d.items():
print(k, v)
# a 1
# b 2
# c 3
# 迭代字符串
for ch in 'abc':
print(ch)
# a b c4
# 实现下标循环 enumerate函数
for i, value in enumerate(['A', 'B', 'C']):
print(i, value)
# 0 A
# 1 B
# 2 C
# 同时引用两个变量
for x, y in [(1,1), (2, 4), (3, 9)]:
print(x, y)
# 1 1
# 2 4
# 3 9
# 判断是否为可迭代对象
from collections.abc import Iterable
print(isinstance('abc', Iterable)) # str 是否可以迭代
# True
print(isinstance([1,2,3], Iterable)) # list 是否可以迭代
# True
print(isinstance(123, Iterable)) # 整数是否可迭
# False
list(range(1,11)) # 生成1-10
print([x * x for x in range(1, 11)]) #生成1*1 2*2···10*10
# [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
print([x * x for x in range(1, 11) if x % 2 == 0]) # 偶数
# [4, 16, 36, 64, 100]
print([m + n for m in 'ABC' for n in 'XYZ']) #组合
# ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
import os # 导入os模块,模块的概念后面讲到
print([d for d in os.listdir('.')]) #os.listdir可以列出文件和目录
d = {'x': 'A', 'y': 'B', 'z': 'C' }
print([k + '=' + v for k, v in d.items()])
# ['x=A', 'y=B', 'z=C']
L = ['Hello', 'World', 'IBM', 'Apple']
print([s.lower() for s in L]) # 变小写
# ['hello', 'world', 'ibm', 'apple']
g = (x * x for x in range(10))
print(next(g)) # 1
print(next(g)) # 4
print(next(g)) # 9
def fib(max):
n, a, b = 0, 0, 1
while n < max:
yield b
a, b = b, a + b
n = n + 1
return 'done'
# 迭代生成器
for n in fib(6):
print(n)
# 拿到生成器的return的返回值
g = fib(6)
while True:
try:
x = next(g)
print('g', x)
except StopIteration as e:
print(e.value)
break
print(g)
1. 安装
Download Windows x86-64 executable installer
windows选择exe安装包。安装时需要勾选环境变量。2. 初识python
python hello.py
运行文件python
就可以进入。exit()
就会离开交互模式3. Python基础
1.数据类型
True False
前端是小写true false
and or not
相对于前端的&& || !
None
2.变量和常量
3. 字符串与编码
3.1 Python的字符串
转字符
ord()
函数获取字符的整数表示chr()
函数把编码 转换为对应的字符 转bytes Python 对bytes
类型的数据用带 bx = b'ABC
如果
bytes
中只有一小部分无效的字节,可以传入errors='ignore'
忽略错误的字节计算字符串的长度
len()
让python是utf-8读取在文件开头
3.2格式化
%是用来格式化字符串的,有几个%,后面就跟几个变量,一个变量时不用加括号
4. list 和 tuple
4.1 list 有序列表
4.2 tuple 元组
5. 条件判断语句(多选一)
6.循环
6.1 三种循环方式
6.2 break continue 关键字(大多数循环并不需要用到 break 和 continue 语句
7. 使用dict 和 set
如果查找的key不存在,就会报错
两个方式检验是否存在
1.用 in 方法, 返回值为布尔值
print('Thomas' in d) # False
2. get()方法 , 不存在返回None
print(d.get('Thomas')) # None
注意: dict的 key 是不可变对象, 可以用字符串和整数做key不可用list做key
7. 函数
7.1内置函数
help(abs)
7.2定义函数
return 函数的返回值,默认为None
空函数 pass(还没想好怎么写,pass可以用来占位,不会报错)
参数检查
函数多个返回值
7.3函数的参数
位置参数
默认参数
注意 :
可变参数 *
关键字参数 **表示,变成dict
命名关键字参数
2. 如果有可变参数存在,就不用在加*了,但是也必须要传入命名参数
def person(name, age , *args, city, job): print(name, age,args, city, job) person('jack',24, city='beijing',job='engineers')
jack 24 () beijing engineers
3. 可用默认参数
def person(name, age , *, city='beijing', job): print(name, age, city, job) person('jack', 24, job = 'engineer')
jack 24 beijing engineers
递归次数过多,会导致栈溢出,用尾递归优化解决