Python学习笔记(一)

供个人学习笔记回顾时使用.

1. 基础

  1. print()输出 input()输入
    r'xxx' xxx字符不需要转义
    '''xxx''' xxx中间字符支持跨行

  2. 由于Python的字符串类型是str,在内存中以Unicode表示,一个字符对应若干个字节。如果要在网络上传输,或者保存到磁盘上,就需要把str变为以字节为单位的bytes。
    Python对bytes类型的数据用带b前缀的单引号或双引号表示:

    	x = b'ABC'
    

    以Unicode表示的str通过encode()方法可以编码为指定的bytes,例如:
    反过来,如果我们从网络或磁盘上读取了字节流,那么读到的数据就是bytes。要把bytes变为str,就需要用decode()方法:
    len()函数计算的是str的字符数,如果换成bytes,len()函数就计算字节数:

    	'中文'.encode('utf-8')
    	b'ABC'.decode('ascii')
    
    	# 如果bytes中只有一小部分无效的字节,可以传入errors='ignore'忽略错误的字节:
    	b'\xe4\xb8\xad\xff'.decode('utf-8', errors='ignore')
    
    	len('中文'.encode('utf-8'))
    	# 6
    
  3. 模板字符串%

    	print('Hi, %s, you have $%d.' % ('你好', 1000000))
    
    	# format函数也可以
    	'Hello, {0}, 成绩提升了 {1:.1f}%'.format('小明', 17.125)
    	# 'Hello, 小明, 成绩提升了 17.1%'
    

    %d, %s, %f, %x - 十六进制, 其余和C语言一样
    %s会自动把数字也转换成字符串, 模板字符串里面如果想表达%的话就写%%

  4. 循环不用多说了, 一个样, forin, while, 记得最后加个:

    	names = ['Michael', 'Bob', 'Tracy']
    	for name in names:
    	    print(name)
    
    	n = 1
    	while n <= 100:
    	    print(n)
    	    n = n + 1
    	print('END')
    
    	# 判断一个对象是可迭代对象
    	from collections import Iterable
    	isinstance('abc', Iterable) #true
    
    	# 获取数组下标
    	for i, value in enumerate(['A', 'B', 'C']):
    	    print(i, value)
    
    	# 循环 + range高级用法1
    	list(range(1, 11))
    	# [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    	# 循环 + range高级用法2
    	[x * x for x in range(1, 11)]
    	# [1, 4, 9, 16, 25, 36, 49, 64, 81, 100]
    	# 循环 + range高级用法3
    	[x * x for x in range(1, 11) if x % 2 == 0]
    	# [4, 16, 36, 64, 100]
    	# 双层循环 + range
    	[m + n for m in 'ABC' for n in 'XYZ']
    	# ['AX', 'AY', 'AZ', 'BX', 'BY', 'BZ', 'CX', 'CY', 'CZ']
    
  5. 条件判断, 这个稍有不同, 为ifxxx elifxxx

2. 类型

2.1. 有序集合list和tuple

list

classmates = ['Michael', 'Bob', 'Tracy']

# list是一个可变的有序表,所以,可以往list中追加元素到末尾:
classmates.append('Adam')
['Michael', 'Bob', 'Tracy', 'Adam']

# 把元素插入到指定的位置,比如索引号为1的位置:
classmates.insert(1, 'Jack')
['Michael', 'Jack', 'Bob', 'Tracy', 'Adam']

# 要删除list末尾的元素,用pop()方法:
classmates.pop()
['Michael', 'Jack', 'Bob', 'Tracy']

# 删除指定位置的元素,用pop(i)方法,其中i是索引位置:
classmates.pop(1)
['Michael', 'Bob', 'Tracy']

# 切片, 类似JS中的Slice, 如果第一个索引是0, 还可以简写classmates [:2]
classmates [0:2]
['Michael', 'Bob']
# -1就是最后一位
classmates [-1]
['Tracy']

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值