赞
踩
默认情况下,Python 3 源码文件以 UTF-8 编码,所有字符串都是 unicode 字符串。 当然你也可以为源码文件指定不同的编码:
# -*- coding: cp-1252 -*-
上述定义允许在源文件中使用 Windows-1252 字符集中的字符编码,对应适合语言为保加利亚语、白罗斯语、马其顿语、俄语、塞尔维亚语。
在 Python 3 中,可以用中文作为变量名,非 ASCII 标识符也是允许的了。
保留字即关键字,我们不能把它们用作任何标识符名称。Python 的标准库提供了一个 keyword 模块,可以输出当前版本的所有关键字:
- >>> import keyword
- >>> keyword.kwlist
- ['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with', 'yield']
Python中单行注释以 # 开头,实例如下:
- #!/usr/bin/python3
-
- # 第一个注释
- print ("Hello, Python!") # 第二个注释
执行以上代码,输出结果为:
Hello, Python!
多行注释可以用多个 # 号,还有 ''' 和 """:
- #!/usr/bin/python3
-
- # 第一个注释
- # 第二个注释
-
- '''
- 第三注释
- 第四注释
- '''
-
- """
- 第五注释
- 第六注释
- """
- print ("Hello, Python!")
执行以上代码,输出结果为:
Hello, Python!
python最具特色的就是使用缩进来表示代码块,不需要使用大括号 {} 。
缩进的空格数是可变的,但是同一个代码块的语句必须包含相同的缩进空格数。实例如下:
- if True:
- print ("True")
- else:
- print ("False")
以下代码最后一行语句缩进数的空格数不一致,会导致运行错误:
- if True:
- print ("Answer")
- print ("True")
- else:
- print ("Answer")
- print ("False") # 缩进不一致,会导致运行错误
以上程序由于缩进不一致,执行后会出现类似以下错误:
- File "test.py", line 6
- print ("False") # 缩进不一致,会导致运行错误
- ^
- IndentationError: unindent does not match any outer indentation level
Python 通常是一行写完一条语句,但如果语句很长,我们可以使用反斜杠 \ 来实现多行语句,例如:
- total = ['item_one', 'item_two', 'item_three',
- 'item_four', 'item_five']
在 [], {}, 或 () 中的多行语句,不需要使用反斜杠 \,例如:
- total = ['item_one', 'item_two', 'item_three',
- 'item_four', 'item_five']
python中数字有四种类型:整数、布尔型、浮点数和复数。
- word = '字符串'
- sentence = "这是一个句子。"
- paragraph = """这是一个段落,
- 可以由多行组成"""
- #!/usr/bin/python3
-
- str='123456789'
-
- print(str) # 输出字符串
- print(str[0:-1]) # 输出第一个到倒数第二个的所有字符
- print(str[0]) # 输出字符串第一个字符
- print(str[2:5]) # 输出从第三个开始到第五个的字符
- print(str[2:]) # 输出从第三个开始后的所有字符
- print(str[1:5:2]) # 输出从第二个开始到第五个且每隔一个的字符(步长为2)
- print(str * 2) # 输出字符串两次
- print(str + '你好') # 连接字符串
-
- print('------------------------------')
-
- print('hello\nrunoob') # 使用反斜杠(\)+n转义特殊字符
- print(r'hello\nrunoob') # 在字符串前面添加一个 r,表示原始字符串,不会发生转义
这里的 r 指 raw,即 raw string,会自动将反斜杠转义,例如:
- >>> print('\n') # 输出空行
-
- >>> print(r'\n') # 输出 \n
- \n
- >>>
以上实例输出结果:
- 123456789
- 12345678
- 1
- 345
- 3456789
- 24
- 123456789123456789
- 123456789你好
- ------------------------------
- hello
- runoob
- hello\nrunoob
函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一行空行分隔,以突出函数入口的开始。
空行与代码缩进不同,空行并不是Python语法的一部分。书写时不插入空行,Python解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码的维护或重构。
记住:空行也是程序代码的一部分。
执行下面的程序在按回车键后就会等待用户输入:
- #!/usr/bin/python3
-
- input("\n\n按下 enter 键后退出。")
以上代码中 ,"\n\n"在结果输出前会输出两个新的空行。一旦用户按下 enter 键时,程序将退出。
Python 可以在同一行中使用多条语句,语句之间使用分号 ; 分割,以下是一个简单的实例:
- #!/usr/bin/python3
-
- import sys; x = 'runoob'; sys.stdout.write(x + '\n')
使用脚本执行以上代码,输出结果为:
runoob
使用交互式命令行执行,输出结果为:
- >>> import sys; x = 'runoob'; sys.stdout.write(x + '\n')
- runoob
- 7
此处的 7 表示字符数。
缩进相同的一组语句构成一个代码块,我们称之代码组。
像if、while、def和class这样的复合语句,首行以关键字开始,以冒号( : )结束,该行之后的一行或多行代码构成代码组。
我们将首行及后面的代码组称为一个子句(clause)。
如下实例:
- if expression :
- suite
- elif expression :
- suite
- else :
- suite
print 默认输出是换行的,如果要实现不换行需要在变量末尾加上 end="":
- #!/usr/bin/python3
-
- x="a"
- y="b"
- # 换行输出
- print( x )
- print( y )
-
- print('---------')
- # 不换行输出
- print( x, end=" " )
- print( y, end=" " )
- print()
以上实例执行结果为:
- a
- b
- ---------
- a b
在 python 用 import 或者 from...import 来导入相应的模块。
将整个模块(somemodule)导入,格式为: import somemodule
从某个模块中导入某个函数,格式为: from somemodule import somefunction
从某个模块中导入多个函数,格式为: from somemodule import firstfunc, secondfunc, thirdfunc
将某个模块中的全部函数导入,格式为: from somemodule import *
- import sys
- print('================Python import mode==========================')
- print ('命令行参数为:')
- for i in sys.argv:
- print (i)
- print ('\n python 路径为',sys.path)
from sys import argv,path # 导入特定的成员 print('================python from import===================================') print('path:',path) # 因为已经导入path成员,所以此处引用时不需要加sys.path
很多程序可以执行一些操作来查看一些基本信息,Python可以使用-h参数查看各参数帮助信息:
- $ python -h
- usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
- Options and arguments (and corresponding environment variables):
- -c cmd : program passed in as string (terminates option list)
- -d : debug output from parser (also PYTHONDEBUG=x)
- -E : ignore environment variables (such as PYTHONPATH)
- -h : print this help message and exit
-
- [ etc. ]
我们在使用脚本形式执行 Python 时,可以接收命令行输入的参数,具体使用可以参照 Python 3 命令行参数。
Python 中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。
在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型。
等号(=)用来给变量赋值。
等号(=)运算符左边是一个变量名,等号(=)运算符右边是存储在变量中的值。例如:
- #!/usr/bin/python3
-
- counter = 100 # 整型变量
- miles = 1000.0 # 浮点型变量
- name = "runoob" # 字符串
-
- print (counter)
- print (miles)
- print (name)
执行以上程序会输出如下结果:
- 100
- 1000.0
- runoob
Python允许你同时为多个变量赋值。例如:
a = b = c = 1
以上实例,创建一个整型对象,值为 1,从后向前赋值,三个变量被赋予相同的数值。
您也可以为多个对象指定多个变量。例如:
a, b, c = 1, 2, "runoob"
以上实例,两个整型对象 1 和 2 的分配给变量 a 和 b,字符串对象 "runoob" 分配给变量 c。
Python3 中有六个标准的数据类型:
Python3 的六个标准数据类型中:
Python3 支持 int、float、bool、complex(复数)。
在Python 3里,只有一种整数类型 int,表示为长整型,没有 python2 中的 Long。
像大多数语言一样,数值类型的赋值和计算都是很直观的。
内置的 type() 函数可以用来查询变量所指的对象类型。
- >>> a, b, c, d = 20, 5.5, True, 4+3j
- >>> print(type(a), type(b), type(c), type(d))
- <class 'int'> <class 'float'> <class 'bool'> <class 'complex'>
此外还可以用 isinstance 来判断:
- >>> a = 111
- >>> isinstance(a, int)
- True
- >>>
isinstance 和 type 的区别在于:
- >>> class A:
- ... pass
- ...
- >>> class B(A):
- ... pass
- ...
- >>> isinstance(A(), A)
- True
- >>> type(A()) == A
- True
- >>> isinstance(B(), A)
- True
- >>> type(B()) == A
- False
注意:Python3 中,bool 是 int 的子类,True 和 False 可以和数字相加 True==1,False==0 是会返回 Ture,但可以通过 is 来判断类型。
>>> issubclass(bool, int) True >>> True==1 True >>> False==0 True >>> True+1 2 >>> False+1 1 >>> 1 is True False >>> 0 is False False在 Python2 中是没有布尔型的,它用数字 0 表示 False,用 1 表示 True。
当你指定一个值时,Number 对象就会被创建:
- var1 = 1
- var2 = 10
您也可以使用del语句删除一些对象引用。
del语句的语法是:
del var1[,var2[,var3[....,varN]]]
您可以通过使用del语句删除单个或多个对象。例如:
- del var
- del var_a, var_b
- >>> 5 + 4 # 加法
- 9
- >>> 4.3 - 2 # 减法
- 2.3
- >>> 3 * 7 # 乘法
- 21
- >>> 2 / 4 # 除法,得到一个浮点数
- 0.5
- >>> 2 // 4 # 除法,得到一个整数
- 0
- >>> 17 % 3 # 取余
- 2
- >>> 2 ** 5 # 乘方
- 32
注意:
int | float | complex |
---|---|---|
10 | 0.0 | 3.14j |
100 | 15.20 | 45.j |
-786 | -21.9 | 9.322e-36j |
080 | 32.3e+18 | .876j |
-0490 | -90. | -.6545+0J |
-0x260 | -32.54e100 | 3e+26J |
0x69 | 70.2E-12 | 4.53e-7j |
Python还支持复数,复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型
Python中的字符串用单引号 ' 或双引号 " 括起来,同时使用反斜杠 \ 转义特殊字符。
字符串的截取的语法格式如下:
变量[头下标:尾下标]
索引值以 0 为开始值,-1 为从末尾的开始位置。
加号 + 是字符串的连接符, 星号 * 表示复制当前字符串,与之结合的数字为复制的次数。实例如下:
- #!/usr/bin/python3
-
- str = 'Runoob'
-
- print (str) # 输出字符串
- print (str[0:-1]) # 输出第一个到倒数第二个的所有字符
- print (str[0]) # 输出字符串第一个字符
- print (str[2:5]) # 输出从第三个开始到第五个的字符
- print (str[2:]) # 输出从第三个开始的后的所有字符
- print (str * 2) # 输出字符串两次,也可以写成 print (2 * str)
- print (str + "TEST") # 连接字符串
执行以上程序会输出如下结果:
- Runoob
- Runoo
- R
- noo
- noob
- RunoobRunoob
- RunoobTEST
Python 使用反斜杠 \ 转义特殊字符,如果你不想让反斜杠发生转义,可以在字符串前面添加一个 r,表示原始字符串:
- >>> print('Ru\noob')
- Ru
- oob
- >>> print(r'Ru\noob')
- Ru\noob
- >>>
另外,反斜杠(\)可以作为续行符,表示下一行是上一行的延续。也可以使用 """...""" 或者 '''...''' 跨越多行。
注意,Python 没有单独的字符类型,一个字符就是长度为1的字符串。
- >>> word = 'Python'
- >>> print(word[0], word[5])
- P n
- >>> print(word[-1], word[-6])
- n P
与 C 字符串不同的是,Python 字符串不能被改变。向一个索引位置赋值,比如word[0] = 'm'会导致错误。
注意:
List(列表) 是 Python 中使用最频繁的数据类型。
列表可以完成大多数集合类的数据结构实现。列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表(所谓嵌套)。
列表是写在方括号 [] 之间、用逗号分隔开的元素列表。
和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。
列表截取的语法格式如下:
变量[头下标:尾下标]
索引值以 0 为开始值,-1 为从末尾的开始位置。
加号 + 是列表连接运算符,星号 * 是重复操作。如下实例:
- #!/usr/bin/python3
-
- list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
- tinylist = [123, 'runoob']
-
- print (list) # 输出完整列表
- print (list[0]) # 输出列表第一个元素
- print (list[1:3]) # 从第二个开始输出到第三个元素
- print (list[2:]) # 输出从第三个元素开始的所有元素
- print (tinylist * 2) # 输出两次列表
- print (list + tinylist) # 连接列表
以上实例输出结果:
- ['abcd', 786, 2.23, 'runoob', 70.2]
- abcd
- [786, 2.23]
- [2.23, 'runoob', 70.2]
- [123, 'runoob', 123, 'runoob']
- ['abcd', 786, 2.23, 'runoob', 70.2, 123, 'runoob']
与Python字符串不一样的是,列表中的元素是可以改变的:
- >>> a = [1, 2, 3, 4, 5, 6]
- >>> a[0] = 9
- >>> a[2:5] = [13, 14, 15]
- >>> a
- [9, 2, 13, 14, 15, 6]
- >>> a[2:5] = [] # 将对应的元素值设置为 []
- >>> a
- [9, 2, 6]
List 内置了有很多方法,例如 append()、pop() 等等,这在后面会讲到。
注意:
Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:
如果第三个参数为负数表示逆向读取,以下实例用于翻转字符串:
- def reverseWords(input):
-
- # 通过空格将字符串分隔符,把各个单词分隔为列表
- inputWords = input.split(" ")
-
- # 翻转字符串
- # 假设列表 list = [1,2,3,4],
- # list[0]=1, list[1]=2 ,而 -1 表示最后一个元素 list[-1]=4 ( 与 list[3]=4 一样)
- # inputWords[-1::-1] 有三个参数
- # 第一个参数 -1 表示最后一个元素
- # 第二个参数为空,表示移动到列表末尾
- # 第三个参数为步长,-1 表示逆向
- inputWords=inputWords[-1::-1]
-
- # 重新组合字符串
- output = ' '.join(inputWords)
-
- return output
-
- if __name__ == "__main__":
- input = 'I like runoob'
- rw = reverseWords(input)
- print(rw)
输出结果为:
runoob like I
元组(tuple)与列表类似,不同之处在于元组的元素不能修改。元组写在小括号 () 里,元素之间用逗号隔开。
元组中的元素类型也可以不相同:
- #!/usr/bin/python3
-
- tuple = ( 'abcd', 786 , 2.23, 'runoob', 70.2 )
- tinytuple = (123, 'runoob')
-
- print (tuple) # 输出完整元组
- print (tuple[0]) # 输出元组的第一个元素
- print (tuple[1:3]) # 输出从第二个元素开始到第三个元素
- print (tuple[2:]) # 输出从第三个元素开始的所有元素
- print (tinytuple * 2) # 输出两次元组
- print (tuple + tinytuple) # 连接元组
以上实例输出结果:
- ('abcd', 786, 2.23, 'runoob', 70.2)
- abcd
- (786, 2.23)
- (2.23, 'runoob', 70.2)
- (123, 'runoob', 123, 'runoob')
- ('abcd', 786, 2.23, 'runoob', 70.2, 123, 'runoob')
元组与字符串类似,可以被索引且下标索引从0开始,-1 为从末尾开始的位置。也可以进行截取(看上面,这里不再赘述)。
其实,可以把字符串看作一种特殊的元组。
- >>> tup = (1, 2, 3, 4, 5, 6)
- >>> print(tup[0])
- 1
- >>> print(tup[1:5])
- (2, 3, 4, 5)
- >>> tup[0] = 11 # 修改元组元素的操作是非法的
- Traceback (most recent call last):
- File "<stdin>", line 1, in <module>
- TypeError: 'tuple' object does not support item assignment
- >>>
虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:
- tup1 = () # 空元组
- tup2 = (20,) # 一个元素,需要在元素后添加逗号
string、list 和 tuple 都属于 sequence(序列)。
注意:
集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。
基本功能是进行成员关系测试和删除重复元素。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
创建格式:
- parame = {value01,value02,...}
- 或者
- set(value)
- #!/usr/bin/python3
-
- sites = {'Google', 'Taobao', 'Runoob', 'Facebook', 'Zhihu', 'Baidu'}
-
- print(sites) # 输出集合,重复的元素被自动去掉
-
- # 成员测试
- if 'Runoob' in sites :
- print('Runoob 在集合中')
- else :
- print('Runoob 不在集合中')
-
-
- # set可以进行集合运算
- a = set('abracadabra')
- b = set('alacazam')
-
- print(a)
-
- print(a - b) # a 和 b 的差集
-
- print(a | b) # a 和 b 的并集
-
- print(a & b) # a 和 b 的交集
-
- print(a ^ b) # a 和 b 中不同时存在的元素
以上实例输出结果:
- {'Zhihu', 'Baidu', 'Taobao', 'Runoob', 'Google', 'Facebook'}
- Runoob 在集合中
- {'b', 'c', 'a', 'r', 'd'}
- {'r', 'b', 'd'}
- {'b', 'c', 'a', 'z', 'm', 'r', 'l', 'd'}
- {'c', 'a'}
- {'z', 'b', 'm', 'r', 'l', 'd'}
字典(dictionary)是Python中另一个非常有用的内置数据类型。
列表是有序的对象集合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。
字典是一种映射类型,字典用 { } 标识,它是一个无序的 键(key) : 值(value) 的集合。
键(key)必须使用不可变类型。
在同一个字典中,键(key)必须是唯一的。
- #!/usr/bin/python3
-
- dict = {}
- dict['one'] = "1 - 菜鸟教程"
- dict[2] = "2 - 菜鸟工具"
-
- tinydict = {'name': 'runoob','code':1, 'site': 'www.runoob.com'}
-
-
- print (dict['one']) # 输出键为 'one' 的值
- print (dict[2]) # 输出键为 2 的值
- print (tinydict) # 输出完整的字典
- print (tinydict.keys()) # 输出所有键
- print (tinydict.values()) # 输出所有值
以上实例输出结果:
- 1 - 菜鸟教程
- 2 - 菜鸟工具
- {'name': 'runoob', 'code': 1, 'site': 'www.runoob.com'}
- dict_keys(['name', 'code', 'site'])
- dict_values(['runoob', 1, 'www.runoob.com'])
构造函数 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}
- >>>
另外,字典类型也有一些内置的函数,例如clear()、keys()、values()等。
注意:
有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。
以下几个内置的函数可以执行数据类型之间的转换。这些函数返回一个新的对象,表示转换的值。
函数 | 描述 |
---|---|
将x转换为一个整数 |
|
将x转换到一个浮点数 |
|
创建一个复数 |
|
将对象 x 转换为字符串 |
|
将对象 x 转换为表达式字符串 |
|
用来计算在字符串中的有效Python表达式,并返回一个对象 |
|
将序列 s 转换为一个元组 |
|
将序列 s 转换为一个列表 |
|
转换为可变集合 |
|
创建一个字典。d 必须是一个 (key, value)元组序列。 |
|
转换为不可变集合 |
|
将一个整数转换为一个字符 |
|
将一个字符转换为它的整数值 |
|
将一个整数转换为一个十六进制字符串 |
|
将一个整数转换为一个八进制字符串 |
Linux/Unix的系统上,一般默认的 python 版本为 2.x,我们可以将 python3.x 安装在 /usr/local/python3 目录中。
安装完成后,我们可以将路径 /usr/local/python3/bin 添加到您的 Linux/Unix 操作系统的环境变量中,这样您就可以通过 shell 终端输入下面的命令来启动 Python3 。
- $ PATH=$PATH:/usr/local/python3/bin/python3 # 设置环境变量
- $ python3 --version
- Python 3.4.0
在Window系统下你可以通过以下命令来设置Python的环境变量,假设你的Python安装在 C:\Python34 下:
set path=%path%;C:\python34
我们可以在命令提示符中输入"Python"命令来启动Python解释器:
$ python3
执行以上命令后,出现如下窗口信息:
- $ python3
- Python 3.4.0 (default, Apr 11 2014, 13:05:11)
- [GCC 4.8.2] on linux
- Type "help", "copyright", "credits" or "license" for more information.
- >>>
在 python 提示符中输入以下语句,然后按回车键查看运行效果:
print ("Hello, Python!");
以上命令执行结果如下:
Hello, Python!
当键入一个多行结构时,续行是必须的。我们可以看下如下 if 语句:
- >>> flag = True
- >>> if flag :
- ... print("flag 条件为 True!")
- ...
- flag 条件为 True!
将如下代码拷贝至 hello.py文件中:
print ("Hello, Python!");
通过以下命令执行该脚本:
python3 hello.py
输出结果为:
Hello, Python!
在Linux/Unix系统中,你可以在脚本顶部添加以下命令让Python脚本可以像SHELL脚本一样可直接执行:
#! /usr/bin/env python3
然后修改脚本权限,使其有执行权限,命令如下:
$ chmod +x hello.py
执行以下命令:
./hello.py
输出结果为:
Hello, Python!
确保对模块, 函数, 方法和行内注释使用正确的风格
Python中的注释有单行注释和多行注释:
Python中单行注释以 # 开头,例如::
- # 这是一个注释
- print("Hello, World!")
多行注释用三个单引号 ''' 或者三个双引号 """ 将注释括起来,例如:
- #!/usr/bin/python3
- '''
- 这是多行注释,用三个单引号
- 这是多行注释,用三个单引号
- 这是多行注释,用三个单引号
- '''
- print("Hello, World!")
- #!/usr/bin/python3
- """
- 这是多行注释,用三个双引号
- 这是多行注释,用三个双引号
- 这是多行注释,用三个双引号
- """
- print("Hello, World!")
本章节主要说明 Python 的运算符。
举个简单的例子:
4 + 5 = 9
例子中,4 和 5 被称为操作数,+ 称为运算符。
Python 语言支持以下类型的运算符:
接下来让我们一个个来学习Python的运算符。
以下假设变量 a=10,变量 b=21:
运算符 | 描述 | 实例 |
---|---|---|
+ | 加 - 两个对象相加 | a + b 输出结果 31 |
- | 减 - 得到负数或是一个数减去另一个数 | a - b 输出结果 -11 |
* | 乘 - 两个数相乘或是返回一个被重复若干次的字符串 | a * b 输出结果 210 |
/ | 除 - x 除以 y | b / a 输出结果 2.1 |
% | 取模 - 返回除法的余数 | b % a 输出结果 1 |
** | 幂 - 返回x的y次幂 | a**b 为10的21次方 |
// | 取整除 - 向下取接近商的整数 | |
以下实例演示了Python所有算术运算符的操作:
- #!/usr/bin/python3
-
- a = 21
- b = 10
- c = 0
-
- c = a + b
- print ("1 - c 的值为:", c)
-
- c = a - b
- print ("2 - c 的值为:", c)
-
- c = a * b
- print ("3 - c 的值为:", c)
-
- c = a / b
- print ("4 - c 的值为:", c)
-
- c = a % b
- print ("5 - c 的值为:", c)
-
- # 修改变量 a 、b 、c
- a = 2
- b = 3
- c = a**b
- print ("6 - c 的值为:", c)
-
- a = 10
- b = 5
- c = a//b
- print ("7 - c 的值为:", c)
以上实例输出结果:
- 1 - c 的值为: 31
- 2 - c 的值为: 11
- 3 - c 的值为: 210
- 4 - c 的值为: 2.1
- 5 - c 的值为: 1
- 6 - c 的值为: 8
- 7 - c 的值为: 2
以下假设变量a为10,变量b为20:
运算符 | 描述 | 实例 |
---|---|---|
== | 等于 - 比较对象是否相等 | (a == b) 返回 False。 |
!= | 不等于 - 比较两个对象是否不相等 | (a != b) 返回 True。 |
> | 大于 - 返回x是否大于y | (a > b) 返回 False。 |
< | 小于 - 返回x是否小于y。所有比较运算符返回1表示真,返回0表示假。这分别与特殊的变量True和False等价。注意,这些变量名的大写。 | (a < b) 返回 True。 |
>= | 大于等于 - 返回x是否大于等于y。 | (a >= b) 返回 False。 |
<= | 小于等于 - 返回x是否小于等于y。 | (a <= b) 返回 True。 |
以下实例演示了Python所有比较运算符的操作:
- #!/usr/bin/python3
-
- a = 21
- b = 10
- c = 0
-
- if ( a == b ):
- print ("1 - a 等于 b")
- else:
- print ("1 - a 不等于 b")
-
- if ( a != b ):
- print ("2 - a 不等于 b")
- else:
- print ("2 - a 等于 b")
-
- if ( a < b ):
- print ("3 - a 小于 b")
- else:
- print ("3 - a 大于等于 b")
-
- if ( a > b ):
- print ("4 - a 大于 b")
- else:
- print ("4 - a 小于等于 b")
-
- # 修改变量 a 和 b 的值
- a = 5
- b = 20
- if ( a <= b ):
- print ("5 - a 小于等于 b")
- else:
- print ("5 - a 大于 b")
-
- if ( b >= a ):
- print ("6 - b 大于等于 a")
- else:
- print ("6 - b 小于 a")
以上实例输出结果:
- 1 - a 不等于 b
- 2 - a 不等于 b
- 3 - a 大于等于 b
- 4 - a 大于 b
- 5 - a 小于等于 b
- 6 - b 大于等于 a
以下假设变量a为10,变量b为20:
运算符 | 描述 | 实例 |
---|---|---|
= | 简单的赋值运算符 | c = a + b 将 a + b 的运算结果赋值为 c |
+= | 加法赋值运算符 | c += a 等效于 c = c + a |
-= | 减法赋值运算符 | c -= a 等效于 c = c - a |
*= | 乘法赋值运算符 | c *= a 等效于 c = c * a |
/= | 除法赋值运算符 | c /= a 等效于 c = c / a |
%= | 取模赋值运算符 | c %= a 等效于 c = c % a |
**= | 幂赋值运算符 | c **= a 等效于 c = c ** a |
//= | 取整除赋值运算符 | c //= a 等效于 c = c // a |
:= | 海象运算符,可在表达式内部为变量赋值。Python3.8 版本新增运算符。 | 在这个示例中,赋值表达式可以避免调用 len() 两次: |
以下实例演示了Python所有赋值运算符的操作:
- #!/usr/bin/python3
-
- a = 21
- b = 10
- c = 0
-
- c = a + b
- print ("1 - c 的值为:", c)
-
- c += a
- print ("2 - c 的值为:", c)
-
- c *= a
- print ("3 - c 的值为:", c)
-
- c /= a
- print ("4 - c 的值为:", c)
-
- c = 2
- c %= a
- print ("5 - c 的值为:", c)
-
- c **= a
- print ("6 - c 的值为:", c)
-
- c //= a
- print ("7 - c 的值为:", c)
以上实例输出结果:
- 1 - c 的值为: 31
- 2 - c 的值为: 52
- 3 - c 的值为: 1092
- 4 - c 的值为: 52.0
- 5 - c 的值为: 2
- 6 - c 的值为: 2097152
- 7 - c 的值为: 99864
按位运算符是把数字看作二进制来进行计算的。Python中的按位运算法则如下:
下表中变量 a 为 60,b 为 13二进制格式如下:
- a = 0011 1100
-
- b = 0000 1101
-
- -----------------
-
- a&b = 0000 1100
-
- a|b = 0011 1101
-
- a^b = 0011 0001
-
- ~a = 1100 0011
运算符 | 描述 | 实例 |
---|---|---|
& | 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 | (a & b) 输出结果 12 ,二进制解释: 0000 1100 |
| | 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 | (a | b) 输出结果 61 ,二进制解释: 0011 1101 |
^ | 按位异或运算符:当两对应的二进位相异时,结果为1 | (a ^ b) 输出结果 49 ,二进制解释: 0011 0001 |
~ | 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1。~x 类似于 -x-1 | (~a ) 输出结果 -61 ,二进制解释: 1100 0011, 在一个有符号二进制数的补码形式。 |
<< | 左移动运算符:运算数的各二进位全部左移若干位,由"<<"右边的数指定移动的位数,高位丢弃,低位补0。 | a << 2 输出结果 240 ,二进制解释: 1111 0000 |
>> | 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,">>"右边的数指定移动的位数 | a >> 2 输出结果 15 ,二进制解释: 0000 1111 |
以下实例演示了Python所有位运算符的操作:
- #!/usr/bin/python3
-
- a = 60 # 60 = 0011 1100
- b = 13 # 13 = 0000 1101
- c = 0
-
- c = a & b # 12 = 0000 1100
- print ("1 - c 的值为:", c)
-
- c = a | b # 61 = 0011 1101
- print ("2 - c 的值为:", c)
-
- c = a ^ b # 49 = 0011 0001
- print ("3 - c 的值为:", c)
-
- c = ~a # -61 = 1100 0011
- print ("4 - c 的值为:", c)
-
- 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
Python语言支持逻辑运算符,以下假设变量 a 为 10, b为 20:
运算符 | 逻辑表达式 | 描述 | 实例 |
---|---|---|---|
and | x and y | 布尔"与" - 如果 x 为 False,x and y 返回 x 的值,否则返回 y 的计算值。 | (a and b) 返回 20。 |
or | x or y | 布尔"或" - 如果 x 是 True,它返回 x 的值,否则它返回 y 的计算值。 | (a or b) 返回 10。 |
not | not x | 布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。 | not(a and b) 返回 False |
以上实例输出结果:
- #!/usr/bin/python3
-
- a = 10
- b = 20
-
- if ( a and b ):
- print ("1 - 变量 a 和 b 都为 true")
- else:
- print ("1 - 变量 a 和 b 有一个不为 true")
-
- if ( a or b ):
- print ("2 - 变量 a 和 b 都为 true,或其中一个变量为 true")
- else:
- print ("2 - 变量 a 和 b 都不为 true")
-
- # 修改变量 a 的值
- a = 0
- if ( a and b ):
- print ("3 - 变量 a 和 b 都为 true")
- else:
- print ("3 - 变量 a 和 b 有一个不为 true")
-
- if ( a or b ):
- print ("4 - 变量 a 和 b 都为 true,或其中一个变量为 true")
- else:
- print ("4 - 变量 a 和 b 都不为 true")
-
- if not( a and b ):
- print ("5 - 变量 a 和 b 都为 false,或其中一个变量为 false")
- else:
- print ("5 - 变量 a 和 b 都为 true")
以上实例输出结果:
- 1 - 变量 a 和 b 都为 true
- 2 - 变量 a 和 b 都为 true,或其中一个变量为 true
- 3 - 变量 a 和 b 有一个不为 true
- 4 - 变量 a 和 b 都为 true,或其中一个变量为 true
- 5 - 变量 a 和 b 都为 false,或其中一个变量为 false
除了以上的一些运算符之外,Python还支持成员运算符,测试实例中包含了一系列的成员,包括字符串,列表或元组。
运算符 | 描述 | 实例 |
---|---|---|
in | 如果在指定的序列中找到值返回 True,否则返回 False。 | x 在 y 序列中 , 如果 x 在 y 序列中返回 True。 |
not in | 如果在指定的序列中没有找到值返回 True,否则返回 False。 | x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。 |
以下实例演示了Python所有成员运算符的操作:
- #!/usr/bin/python3
-
- a = 10
- b = 20
- list = [1, 2, 3, 4, 5 ]
-
- if ( a in list ):
- print ("1 - 变量 a 在给定的列表中 list 中")
- else:
- print ("1 - 变量 a 不在给定的列表中 list 中")
-
- if ( b not in list ):
- print ("2 - 变量 b 不在给定的列表中 list 中")
- else:
- print ("2 - 变量 b 在给定的列表中 list 中")
-
- # 修改变量 a 的值
- a = 2
- if ( a in list ):
- print ("3 - 变量 a 在给定的列表中 list 中")
- else:
- print ("3 - 变量 a 不在给定的列表中 list 中")
以上实例输出结果:
- 1 - 变量 a 不在给定的列表中 list 中
- 2 - 变量 b 不在给定的列表中 list 中
- 3 - 变量 a 在给定的列表中 list 中
身份运算符用于比较两个对象的存储单元
运算符 | 描述 | 实例 |
---|---|---|
is | is 是判断两个标识符是不是引用自一个对象 | x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False |
is not | is not 是判断两个标识符是不是引用自不同对象 | x is not y , 类似 id(a) != id(b)。如果引用的不是同一个对象则返回结果 True,否则返回 False。 |
注: id() 函数用于获取对象内存地址。
以下实例演示了Python所有身份运算符的操作:
- #!/usr/bin/python3
-
- a = 20
- b = 20
-
- if ( a is b ):
- print ("1 - a 和 b 有相同的标识")
- else:
- print ("1 - a 和 b 没有相同的标识")
-
- if ( id(a) == id(b) ):
- print ("2 - a 和 b 有相同的标识")
- else:
- print ("2 - a 和 b 没有相同的标识")
-
- # 修改变量 b 的值
- b = 30
- if ( a is b ):
- print ("3 - a 和 b 有相同的标识")
- else:
- print ("3 - a 和 b 没有相同的标识")
-
- if ( a is not b ):
- print ("4 - a 和 b 没有相同的标识")
- else:
- print ("4 - a 和 b 有相同的标识")
以上实例输出结果:
- 1 - a 和 b 有相同的标识
- 2 - a 和 b 有相同的标识
- 3 - a 和 b 没有相同的标识
- 4 - a 和 b 没有相同的标识
is 与 == 区别:
is 用于判断两个变量引用对象是否为同一个, == 用于判断引用变量的值是否相等。
>>>a = [1, 2, 3] >>> b = a >>> b is a True >>> b == a True >>> b = a[:] >>> b is a False >>> b == a True
以下表格列出了从最高到最低优先级的所有运算符:
运算符 | 描述 |
---|---|
** | 指数 (最高优先级) |
~ + - | 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@) |
* / % // | 乘,除,求余数和取整除 |
+ - | 加法减法 |
>> << | 右移,左移运算符 |
& | 位 'AND' |
^ | | 位运算符 |
<= < > >= | 比较运算符 |
== != | 等于运算符 |
= %= /= //= -= += *= **= | 赋值运算符 |
is is not | 身份运算符 |
in not in | 成员运算符 |
not and or | 逻辑运算符 |
以下实例演示了Python所有运算符优先级的操作:
- #!/usr/bin/python3
-
- a = 20
- b = 10
- c = 15
- d = 5
- e = 0
-
- e = (a + b) * c / d #( 30 * 15 ) / 5
- print ("(a + b) * c / d 运算结果为:", e)
-
- e = ((a + b) * c) / d # (30 * 15 ) / 5
- print ("((a + b) * c) / d 运算结果为:", e)
-
- e = (a + b) * (c / d) # (30) * (15/5)
- print ("(a + b) * (c / d) 运算结果为:", e)
-
- e = a + (b * c) / d # 20 + (150/5)
- print ("a + (b * c) / d 运算结果为:", e)
以上实例输出结果:
- (a + b) * c / d 运算结果为: 90.0
- ((a + b) * c) / d 运算结果为: 90.0
- (a + b) * (c / d) 运算结果为: 90.0
- a + (b * c) / d 运算结果为: 50.0
and 拥有更高优先级:
- x = True
- y = False
- z = False
-
- if x or y and z:
- print("yes")
- else:
- print("no")
以上实例输出结果:
yes
注意:Pyhton3 已不支持 <> 运算符,可以使用 != 代替,如果你一定要使用这种比较运算符,可以使用以下的方式:
- >>> from __future__ import barry_as_FLUFL
- >>> 1 <> 2
- True
Python 数字数据类型用于存储数值。
数据类型是不允许改变的,这就意味着如果改变数字数据类型的值,将重新分配内存空间。
以下实例在变量赋值时 Number 对象将被创建:
- var1 = 1
- var2 = 10
您也可以使用del语句删除一些数字对象的引用。
del语句的语法是:
del var1[,var2[,var3[....,varN]]]
您可以通过使用del语句删除单个或多个对象的引用,例如:
- del var
- del var_a, var_b
Python 支持三种不同的数值类型:
整型(int) - 通常被称为是整型或整数,是正或负整数,不带小数点。Python3 整型是没有限制大小的,可以当作 Long 类型使用,所以 Python3 没有 Python2 的 Long 类型。布尔(bool)是整型的子类型。
浮点型(float) - 浮点型由整数部分与小数部分组成,浮点型也可以使用科学计数法表示(2.5e2 = 2.5 x 102 = 250)
复数( (complex)) - 复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型。
我们可以使用十六进制和八进制来代表整数:
- >>> number = 0xA0F # 十六进制
- >>> number
- 2575
-
- >>> number=0o37 # 八进制
- >>> number
- 31
int | float | complex |
---|---|---|
10 | 0.0 | 3.14j |
100 | 15.20 | 45.j |
-786 | -21.9 | 9.322e-36j |
080 | 32.3e+18 | .876j |
-0490 | -90. | -.6545+0J |
-0x260 | -32.54e100 | 3e+26J |
0x69 | 70.2E-12 | 4.53e-7j |
有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。
int(x) 将x转换为一个整数。
float(x) 将x转换到一个浮点数。
complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。
complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。
以下实例将浮点数变量 a 转换为整数:
- >>> a = 1.0
- >>> int(a)
- 1
Python 解释器可以作为一个简单的计算器,您可以在解释器里输入一个表达式,它将输出表达式的值。
表达式的语法很直白: +, -, * 和 /, 和其它语言(如Pascal或C)里一样。例如:
- >>> 2 + 2
- 4
- >>> 50 - 5*6
- 20
- >>> (50 - 5*6) / 4
- 5.0
- >>> 8 / 5 # 总是返回一个浮点数
- 1.6
注意:在不同的机器上浮点运算的结果可能会不一样。
在整数除法中,除法 / 总是返回一个浮点数,如果只想得到整数的结果,丢弃可能的分数部分,可以使用运算符 // :
- >>> 17 / 3 # 整数除法返回浮点型
- 5.666666666666667
- >>>
- >>> 17 // 3 # 整数除法返回向下取整后的结果
- 5
- >>> 17 % 3 # %操作符返回除法的余数
- 2
- >>> 5 * 3 + 2
- 17
注意:// 得到的并不一定是整数类型的数,它与分母分子的数据类型有关系。
- >>> 7//2
- 3
- >>> 7.0//2
- 3.0
- >>> 7//2.0
- 3.0
- >>>
等号 = 用于给变量赋值。赋值之后,除了下一个提示符,解释器不会显示任何结果。
- >>> width = 20
- >>> height = 5*9
- >>> width * height
- 900
Python 可以使用 ** 操作来进行幂运算:
- >>> 5 ** 2 # 5 的平方
- 25
- >>> 2 ** 7 # 2的7次方
- 128
变量在使用前必须先"定义"(即赋予变量一个值),否则会出现错误:
- >>> n # 尝试访问一个未定义的变量
- Traceback (most recent call last):
- File "<stdin>", line 1, in <module>
- NameError: name 'n' is not defined
不同类型的数混合运算时会将整数转换为浮点数:
- >>> 3 * 3.75 / 1.5
- 7.5
- >>> 7.0 / 2
- 3.5
在交互模式中,最后被输出的表达式结果被赋值给变量 _ 。例如:
- >>> tax = 12.5 / 100
- >>> price = 100.50
- >>> price * tax
- 12.5625
- >>> price + _
- 113.0625
- >>> round(_, 2)
- 113.06
此处, _ 变量应被用户视为只读变量。
函数 | 返回值 ( 描述 ) |
---|---|
abs(x) | 返回数字的绝对值,如abs(-10) 返回 10 |
ceil(x) | 返回数字的上入整数,如math.ceil(4.1) 返回 5 |
cmp(x, y) |
如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。 Python 3 已废弃,使用 (x>y)-(x<y) 替换。 |
exp(x) | 返回e的x次幂(ex),如math.exp(1) 返回2.718281828459045 |
fabs(x) | 返回数字的绝对值,如math.fabs(-10) 返回10.0 |
floor(x) | 返回数字的下舍整数,如math.floor(4.9)返回 4 |
log(x) | 如math.log(math.e)返回1.0,math.log(100,10)返回2.0 |
log10(x) | 返回以10为基数的x的对数,如math.log10(100)返回 2.0 |
max(x1, x2,...) | 返回给定参数的最大值,参数可以为序列。 |
min(x1, x2,...) | 返回给定参数的最小值,参数可以为序列。 |
modf(x) | 返回x的整数部分与小数部分,两部分的数值符号与x相同,整数部分以浮点型表示。 |
pow(x, y) | x**y 运算后的值。 |
round(x [,n]) | 返回浮点数 x 的四舍五入值,如给出 n 值,则代表舍入到小数点后的位数。 其实准确的说是保留值将保留到离上一位更近的一端。 |
sqrt(x) | 返回数字x的平方根。 |
随机数可以用于数学,游戏,安全等领域中,还经常被嵌入到算法中,用以提高算法效率,并提高程序的安全性。
Python包含以下常用随机数函数:
函数 | 描述 |
---|---|
choice(seq) | 从序列的元素中随机挑选一个元素,比如random.choice(range(10)),从0到9中随机挑选一个整数。 |
randrange ([start,] stop [,step]) | 从指定范围内,按指定基数递增的集合中获取一个随机数,基数默认值为 1 |
random() | 随机生成下一个实数,它在[0,1)范围内。 |
seed([x]) | 改变随机数生成器的种子seed。如果你不了解其原理,你不必特别去设定seed,Python会帮你选择seed。 |
shuffle(lst) | 将序列的所有元素随机排序 |
uniform(x, y) | 随机生成下一个实数,它在[x,y]范围内。 |
Python包括以下三角函数:
函数 | 描述 |
---|---|
acos(x) | 返回x的反余弦弧度值。 |
asin(x) | 返回x的反正弦弧度值。 |
atan(x) | 返回x的反正切弧度值。 |
atan2(y, x) | 返回给定的 X 及 Y 坐标值的反正切值。 |
cos(x) | 返回x的弧度的余弦值。 |
hypot(x, y) | 返回欧几里德范数 sqrt(x*x + y*y)。 |
sin(x) | 返回的x弧度的正弦值。 |
tan(x) | 返回x弧度的正切值。 |
degrees(x) | 将弧度转换为角度,如degrees(math.pi/2) , 返回90.0 |
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。