多行语法
- Python 可以同一行显示多条语句,方法是用分号 ; 分开
print ('hello');print ('runoob'); #注意最后也要加分号
严格缩进
- 在 Python 的代码块中必须使用相同数目的行首缩进空格数
注释
- 单行注释采用 # 开头
- 多行注释使用三个单引号(’’’)或三个双引号(""")。
print输出
- print 默认输出是换行的,如果要实现不换行需要在变量末尾加上逗号 ,。
print('hello\nrunoob') # 使用反斜杠(\)+n转义特殊字符
print(r'hello\nrunoob') # 在字符串前面添加一个r,表示原始字符串,不会发生转义
输出为
hello
runoob
hello\nrunoob
索引
- 从左到右索引默认0开始的,最大范围是字符串长度少1
- 从右到左索引默认-1开始的,最大范围是字符串开头
- 加号(+)是字符串连接运算符,星号(*)是重复操作。
str = 'Hello World!'
print (str) # 输出完整字符串
print (str[0]) # 输出字符串中的第一个字符
print (str[2:5]) # 输出字符串中第三个至第六个之间的字符串
print (str[2:]) # 输出从第三个字符开始的字符串
print (str * 2) # 输出字符串两次
print (str + "TEST") # 输出连接的字符串
输出为
Hello World!
H
llo
llo World!
Hello World!Hello World!
HelloWorld!TEST
import与from import
- 将整个模块(somemodule)导入,格式为:
import somemodule
- 从某个模块中导入某个函数,格式为:
from somemodule import somefunction
- 从某个模块中导入多个函数,格式为:
from somemodule import firstfunc, secondfunc,thirdfunc
- 将某个模块中的全部函数导入,格式为:
from somemodule import *
数据类型
List(列表)
- 支持字符,数字,字符串甚至可以包含列表(即嵌套)
- 用 [ ] 标识,是 python 最通用的复合数据类型
list = [ 'runoob', 786 , 2.23, 'john', 70.2 ]
tinylist = [123, 'john']
print (list) # 输出完整列表
print (list[0]) # 输出列表的第一个元素
print (list[1:3]) # 输出第二个至第三个元素
print (list[2:]) # 输出从第三个开始至列表末尾的所有元素
print (tinylist * 2) # 输出列表两次
print (list + tinylist) # 打印组合的列表
输出为
[‘runoob’, 786, 2.23, ‘john’, 70.2]
runoob
[786, 2.23]
[2.23, ‘john’,70.2]
[123, ‘john’, 123, ‘john’]
[‘runoob’, 786, 2.23, ‘john’, 70.2, 123, ‘john’]
元组
- 元组用 () 标识
- 内部元素用逗号隔开。但是元组不能二次赋值(List可以),相当于只读列表。
- 元组中只包含一个元素时,需要在元素后面添加逗号,否则括号会被当作运算符使用
tuple = ( 'runoob', 786 , 2.23, 'john', 70.2 )
tinytuple = (123, 'john')
print (tuple) # 输出完整元组
print (tuple[0]) # 输出元组的第一个元素
print (tuple[1:3]) # 输出第二个至第四个(不包含)的元素
print (tuple[2:]) # 输出从第三个开始至列表末尾的所有元素
print (tinytuple * 2) # 输出元组两次
print (tuple + tinytuple) # 打印组合的元组
输出为
(‘runoob’, 786, 2.23, ‘john’, 70.2)
runoob
(786, 2.23)
(2.23, ‘john’,70.2)
(123, ‘john’, 123, ‘john’)
(‘runoob’, 786, 2.23, ‘john’, 70.2, 123, ‘john’)
字典
- 列表是有序的对象集合,字典是无序的对象集合
- 元素是通过键来存取的,而不是通过偏移存取,用"{ }"标识。字典由索引(key)和它对应的值value组成
- 字典的关键字必须为不可变类型,且不能重复
- 构造函数 dict() 可以直接从键值对序列中构建字典如下:
>>> dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
>>> {x: x**2 for x in (2, 4, 6)}
{2: 4, 4: 16, 6: 36}
>>> dict(Runoob=1, Google=2, Taobao=3)
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
>>>
dict = {}
dict['one'] = "This is one"
dict[2] = "This is two"
tinydict = {'name': 'runoob','code':6734, 'dept': 'sales'}
print (dict['one']) # 输出键为'one' 的值
print (dict[2]) # 输出键为 2 的值
print (tinydict) # 输出完整的字典
print (tinydict.keys()) # 输出所有键
print (tinydict.values()) # 输出所有值
输出为
This is one
This is two
{‘dept’: ‘sales’, ‘code’: 6734, ‘name’:‘runoob’}
[‘dept’, ‘code’, ‘name’]
[‘sales’, 6734, ‘runoob’]
Set集合
- 基本功能是进行成员关系测试和删除重复元素。
- 可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
site = {'Google','Taobao','Google','Facebook','Zhihu'}
print(site) # 输出集合,重复的元素被自动去掉
#成员测试
if 'Taoao' in site:
print('Taoao 在集合中')
else:
print('Taoao 不在集合中')
#set可以进行集合运算
a = set('asdfghjkl')
b = set('asdwd')
print(a)
print(b)
print(b - a) # a 和 b 的差集
print(a | b) # a 和 b 的并集
print(a & b) # a 和 b 的交集
print(a ^ b) # a 和 b 的不同时存在的元素
输出为:
{‘Taobao’, ‘Facebook’, ‘Zhihu’, ‘Google’}
Taoao 不在集合中
{‘f’, ‘k’, ‘g’, ‘l’, ‘a’, ‘d’, ‘s’, ‘h’, ‘j’}
{‘s’, ‘w’, ‘a’, ‘d’}
{‘w’}
{‘f’, ‘k’, ‘g’, ‘l’, ‘w’, ‘a’, ‘d’, ‘s’, ‘h’, ‘j’}
{‘s’, ‘a’, ‘d’}
{‘f’, ‘k’, ‘g’, ‘l’, ‘w’, ‘h’, ‘j’}
数据类型转换
函数 | 描述 |
---|---|
int(x [,base]) | 将x转换为一个整数 |
float(x) | 将x转换到一个浮点数 |
complex(real [,imag]) | 创建一个复数 |
str(x) | 将对象 x 转换为字符串 |
repr(x) | 将对象 x 转换为表达式字符串 |
eval(str) | 用来计算在字符串中的有效Python表达式,并返回一个对象 |
tuple(s) | 将序列 s 转换为一个元组 |
list(s) | 将序列 s 转换为一个列表 |
set(s) | 转换为可变集合 |
dict(d) | 创建一个字典。d 必须是一个序列 (key,value)元组。 |
frozenset(s) | 转换为不可变集合 |
chr(x) | 将一个整数转换为一个字符 |
ord(x) | 将一个字符转换为它的整数值 |
hex(x) | 将一个整数转换为一个十六进制字符串 |
oct(x) | 将一个整数转换为一个八进制字符串 |
数值运算
>>> 5 + 4 # 加法
9
>>> 4.3 - 2 # 减法
2.3
>>> 3 * 7 # 乘法
21
>>> 2 / 4 # 除法,得到一个浮点数
0.5
>>> 2 // 4 # 取整除 - 向下取接近商的整数
0
>>> 17 % 3 # 取余
2
>>> 2 ** 5 # 乘方
32
赋值运算符
a = 21
b = 10
c = 0
print(a)
print(b)
print(c)
c = a + b
print("a + b 的值为:", c)
c += a
print("c += a 的值为:", c)
c *= a
print("c *= a 的值为:", c)
c /= a
print("c /= a 的值为:", c)
c = 2
c %= a
print("c %= a 的值为:", c)
c **= a
print("c **= a 的值为:", c)
c //= a # // 得到的并不一定是整数类型的数,它与分母分子的数据类型有关系。
print("c //= a 的值为:", c)
输出为:
21
10
0
a + b 的值为: 31
c += a 的值为: 52
c *= a 的值为: 1092
c /= a 的值为: 52.0
c %= a 的值为: 2
c **= a 的值为: 2097152
c //= a 的值为: 99864
位运算符
a = 60 # 60 = 0011 1100
b = 13 # 13 = 0000 1101
c = 0
# & 参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0
c = a & b # 12 = 0000 1100
print ("1 - c 的值为:", c)
# | 只要对应的二个二进位有一个为1时,结果位就为1
c = a | b # 61 = 0011 1101
print ("2 - c 的值为:", c)
# ^ 当两对应的二进位相异时,结果为1
c = a ^ b # 49 = 0011 0001
print ("3 - c 的值为:", c)
# ~ 对数据的每个二进制位取反,即把1变为0,把0变为1。~x 类似于 -x-1
c = ~a # -61 = 1100 0011
print ("4 - c 的值为:", c)
# << 运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0
c = a << 2 # 240 = 1111 0000
print ("5 - c 的值为:", c)
# >> 把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数
c = a >> 2 # 15 = 0000 1111
print ("6 - c 的值为:", c)
输出为:
1 - c 的值为: 12
2 - c 的值为: 61
3 - c 的值为: 49
4 - c 的值为: -61
5 - c 的值为: 240
6 - c 的值为: 15