当前位置:   article > 正文

Python3 基础语法_-*- coding: cp-1252 -*

-*- coding: cp-1252 -*

Python3 基础语法

编码

默认情况下,Python 3 源码文件以 UTF-8 编码,所有字符串都是 unicode 字符串。 当然你也可以为源码文件指定不同的编码:

# -*- coding: cp-1252 -*-

上述定义允许在源文件中使用 Windows-1252 字符集中的字符编码,对应适合语言为保加利亚语、白罗斯语、马其顿语、俄语、塞尔维亚语。


标识符

  • 第一个字符必须是字母表中字母或下划线 _ 。
  • 标识符的其他的部分由字母、数字和下划线组成。
  • 标识符对大小写敏感。

在 Python 3 中,可以用中文作为变量名,非 ASCII 标识符也是允许的了。


python保留字

保留字即关键字,我们不能把它们用作任何标识符名称。Python 的标准库提供了一个 keyword 模块,可以输出当前版本的所有关键字:

  1. >>> import keyword
  2. >>> keyword.kwlist
  3. ['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中单行注释以 # 开头,实例如下:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. # 第一个注释
  3. print ("Hello, Python!") # 第二个注释

执行以上代码,输出结果为:

Hello, Python!

多行注释可以用多个 # 号,还有 ''' 和 """:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. # 第一个注释
  3. # 第二个注释
  4. '''
  5. 第三注释
  6. 第四注释
  7. '''
  8. """
  9. 第五注释
  10. 第六注释
  11. """
  12. print ("Hello, Python!")

执行以上代码,输出结果为:

Hello, Python!

行与缩进

python最具特色的就是使用缩进来表示代码块,不需要使用大括号 {} 。

缩进的空格数是可变的,但是同一个代码块的语句必须包含相同的缩进空格数。实例如下:

实例(Python 3.0+)

  1. if True:
  2. print ("True")
  3. else:
  4. print ("False")

以下代码最后一行语句缩进数的空格数不一致,会导致运行错误:

实例

  1. if True:
  2. print ("Answer")
  3. print ("True")
  4. else:
  5. print ("Answer")
  6. print ("False") # 缩进不一致,会导致运行错误

以上程序由于缩进不一致,执行后会出现类似以下错误:

  1. File "test.py", line 6
  2. print ("False") # 缩进不一致,会导致运行错误
  3. ^
  4. IndentationError: unindent does not match any outer indentation level

多行语句

Python 通常是一行写完一条语句,但如果语句很长,我们可以使用反斜杠 \ 来实现多行语句,例如:

  1. total = ['item_one', 'item_two', 'item_three',
  2. 'item_four', 'item_five']

在 [], {}, 或 () 中的多行语句,不需要使用反斜杠 \,例如:

  1. total = ['item_one', 'item_two', 'item_three',
  2. 'item_four', 'item_five']

数字(Number)类型

python中数字有四种类型:整数、布尔型、浮点数和复数。

  • int (整数), 如 1, 只有一种整数类型 int,表示为长整型,没有 python2 中的 Long。
  • bool (布尔), 如 True。
  • float (浮点数), 如 1.23、3E-2
  • complex (复数), 如 1 + 2j、 1.1 + 2.2j

字符串(String)

  • python中单引号和双引号使用完全相同。
  • 使用三引号(''' 或 """)可以指定一个多行字符串。
  • 转义符 \
  • 反斜杠可以用来转义,使用r可以让反斜杠不发生转义。。 如 r"this is a line with \n" 则\n会显示,并不是换行。
  • 按字面意义级联字符串,如"this " "is " "string"会被自动转换为this is string。
  • 字符串可以用 + 运算符连接在一起,用 * 运算符重复。
  • Python 中的字符串有两种索引方式,从左往右以 0 开始,从右往左以 -1 开始。
  • Python中的字符串不能改变。
  • Python 没有单独的字符类型,一个字符就是长度为 1 的字符串。
  • 字符串的截取的语法格式如下:变量[头下标:尾下标:步长]
  1. word = '字符串'
  2. sentence = "这是一个句子。"
  3. paragraph = """这是一个段落,
  4. 可以由多行组成"""

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. str='123456789'
  3. print(str) # 输出字符串
  4. print(str[0:-1]) # 输出第一个到倒数第二个的所有字符
  5. print(str[0]) # 输出字符串第一个字符
  6. print(str[2:5]) # 输出从第三个开始到第五个的字符
  7. print(str[2:]) # 输出从第三个开始后的所有字符
  8. print(str[1:5:2]) # 输出从第二个开始到第五个且每隔一个的字符(步长为2)
  9. print(str * 2) # 输出字符串两次
  10. print(str + '你好') # 连接字符串
  11. print('------------------------------')
  12. print('hello\nrunoob') # 使用反斜杠(\)+n转义特殊字符
  13. print(r'hello\nrunoob') # 在字符串前面添加一个 r,表示原始字符串,不会发生转义

这里的 r 指 raw,即 raw string,会自动将反斜杠转义,例如:

  1. >>> print('\n') # 输出空行
  2. >>> print(r'\n') # 输出 \n
  3. \n
  4. >>>

以上实例输出结果:

  1. 123456789
  2. 12345678
  3. 1
  4. 345
  5. 3456789
  6. 24
  7. 123456789123456789
  8. 123456789你好
  9. ------------------------------
  10. hello
  11. runoob
  12. hello\nrunoob

空行

函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一行空行分隔,以突出函数入口的开始。

空行与代码缩进不同,空行并不是Python语法的一部分。书写时不插入空行,Python解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码的维护或重构。

记住:空行也是程序代码的一部分。


等待用户输入

执行下面的程序在按回车键后就会等待用户输入:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. input("\n\n按下 enter 键后退出。")

以上代码中 ,"\n\n"在结果输出前会输出两个新的空行。一旦用户按下 enter 键时,程序将退出。


同一行显示多条语句

Python 可以在同一行中使用多条语句,语句之间使用分号 ; 分割,以下是一个简单的实例:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. import sys; x = 'runoob'; sys.stdout.write(x + '\n')

使用脚本执行以上代码,输出结果为:

runoob

使用交互式命令行执行,输出结果为:

  1. >>> import sys; x = 'runoob'; sys.stdout.write(x + '\n')
  2. runoob
  3. 7

此处的 7 表示字符数。


多个语句构成代码组

缩进相同的一组语句构成一个代码块,我们称之代码组。

像if、while、def和class这样的复合语句,首行以关键字开始,以冒号( : )结束,该行之后的一行或多行代码构成代码组。

我们将首行及后面的代码组称为一个子句(clause)。

如下实例:

  1. if expression :
  2. suite
  3. elif expression :
  4. suite
  5. else :
  6. suite

print 输出

print 默认输出是换行的,如果要实现不换行需要在变量末尾加上 end="":

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. x="a"
  3. y="b"
  4. # 换行输出
  5. print( x )
  6. print( y )
  7. print('---------')
  8. # 不换行输出
  9. print( x, end=" " )
  10. print( y, end=" " )
  11. print()

以上实例执行结果为:

  1. a
  2. b
  3. ---------
  4. a b

import 与 from...import

在 python 用 import 或者 from...import 来导入相应的模块。

将整个模块(somemodule)导入,格式为: import somemodule

从某个模块中导入某个函数,格式为: from somemodule import somefunction

从某个模块中导入多个函数,格式为: from somemodule import firstfunc, secondfunc, thirdfunc

将某个模块中的全部函数导入,格式为: from somemodule import *

导入 sys 模块

  1. import sys
  2. print('================Python import mode==========================')
  3. print ('命令行参数为:')
  4. for i in sys.argv:
  5. print (i)
  6. print ('\n python 路径为',sys.path)

导入 sys 模块的 argv,path 成员

from sys import argv,path # 导入特定的成员 print('================python from import===================================') print('path:',path) # 因为已经导入path成员,所以此处引用时不需要加sys.path


命令行参数

很多程序可以执行一些操作来查看一些基本信息,Python可以使用-h参数查看各参数帮助信息:

  1. $ python -h
  2. usage: python [option] ... [-c cmd | -m mod | file | -] [arg] ...
  3. Options and arguments (and corresponding environment variables):
  4. -c cmd : program passed in as string (terminates option list)
  5. -d : debug output from parser (also PYTHONDEBUG=x)
  6. -E : ignore environment variables (such as PYTHONPATH)
  7. -h : print this help message and exit
  8. [ etc. ]

我们在使用脚本形式执行 Python 时,可以接收命令行输入的参数,具体使用可以参照 Python 3 命令行参数

Python3 基本数据类型

Python 中的变量不需要声明。每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建。

在 Python 中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象的类型。

等号(=)用来给变量赋值。

等号(=)运算符左边是一个变量名,等号(=)运算符右边是存储在变量中的值。例如:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. counter = 100 # 整型变量
  3. miles = 1000.0 # 浮点型变量
  4. name = "runoob" # 字符串
  5. print (counter)
  6. print (miles)
  7. print (name)


运行实例 »

执行以上程序会输出如下结果:

  1. 100
  2. 1000.0
  3. runoob

多个变量赋值

Python允许你同时为多个变量赋值。例如:

a = b = c = 1

以上实例,创建一个整型对象,值为 1,从后向前赋值,三个变量被赋予相同的数值。

您也可以为多个对象指定多个变量。例如:

a, b, c = 1, 2, "runoob"

以上实例,两个整型对象 1 和 2 的分配给变量 a 和 b,字符串对象 "runoob" 分配给变量 c。


标准数据类型

Python3 中有六个标准的数据类型:

  • Number(数字)
  • String(字符串)
  • List(列表)
  • Tuple(元组)
  • Set(集合)
  • Dictionary(字典)

Python3 的六个标准数据类型中:

  • 不可变数据(3 个):Number(数字)、String(字符串)、Tuple(元组);
  • 可变数据(3 个):List(列表)、Dictionary(字典)、Set(集合)。

Number(数字)

Python3 支持 int、float、bool、complex(复数)

在Python 3里,只有一种整数类型 int,表示为长整型,没有 python2 中的 Long。

像大多数语言一样,数值类型的赋值和计算都是很直观的。

内置的 type() 函数可以用来查询变量所指的对象类型。

  1. >>> a, b, c, d = 20, 5.5, True, 4+3j
  2. >>> print(type(a), type(b), type(c), type(d))
  3. <class 'int'> <class 'float'> <class 'bool'> <class 'complex'>

此外还可以用 isinstance 来判断:

实例

  1. >>> a = 111
  2. >>> isinstance(a, int)
  3. True
  4. >>>

isinstance 和 type 的区别在于:

  • type()不会认为子类是一种父类类型。
  • isinstance()会认为子类是一种父类类型。
  1. >>> class A:
  2. ... pass
  3. ...
  4. >>> class B(A):
  5. ... pass
  6. ...
  7. >>> isinstance(A(), A)
  8. True
  9. >>> type(A()) == A
  10. True
  11. >>> isinstance(B(), A)
  12. True
  13. >>> type(B()) == A
  14. False

注意:Python3 中,bool 是 int 的子类,True 和 False 可以和数字相加 True==1,False==0 是会返回 Ture,但可以通过 is 来判断类型。

  1. >>> issubclass(bool, int)
  2. True
  3. >>> True==1
  4. True
  5. >>> False==0
  6. True
  7. >>> True+1
  8. 2
  9. >>> False+1
  10. 1
  11. >>> 1 is True
  12. False
  13. >>> 0 is False
  14. False

在 Python2 中是没有布尔型的,它用数字 0 表示 False,用 1 表示 True。

当你指定一个值时,Number 对象就会被创建:

  1. var1 = 1
  2. var2 = 10

您也可以使用del语句删除一些对象引用。

del语句的语法是:

del var1[,var2[,var3[....,varN]]]

您可以通过使用del语句删除单个或多个对象。例如:

  1. del var
  2. del var_a, var_b

数值运算

实例

  1. >>> 5 + 4 # 加法
  2. 9
  3. >>> 4.3 - 2 # 减法
  4. 2.3
  5. >>> 3 * 7 # 乘法
  6. 21
  7. >>> 2 / 4 # 除法,得到一个浮点数
  8. 0.5
  9. >>> 2 // 4 # 除法,得到一个整数
  10. 0
  11. >>> 17 % 3 # 取余
  12. 2
  13. >>> 2 ** 5 # 乘方
  14. 32

注意:

  • 1、Python可以同时为多个变量赋值,如a, b = 1, 2。
  • 2、一个变量可以通过赋值指向不同类型的对象。
  • 3、数值的除法包含两个运算符:/ 返回一个浮点数,// 返回一个整数。
  • 4、在混合计算时,Python会把整型转换成为浮点数。

数值类型实例

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都是浮点型


String(字符串)

Python中的字符串用单引号 ' 或双引号 " 括起来,同时使用反斜杠 \ 转义特殊字符。

字符串的截取的语法格式如下:

变量[头下标:尾下标]

索引值以 0 为开始值,-1 为从末尾的开始位置。

加号 + 是字符串的连接符, 星号 * 表示复制当前字符串,与之结合的数字为复制的次数。实例如下:

实例

  1. #!/usr/bin/python3
  2. str = 'Runoob'
  3. print (str) # 输出字符串
  4. print (str[0:-1]) # 输出第一个到倒数第二个的所有字符
  5. print (str[0]) # 输出字符串第一个字符
  6. print (str[2:5]) # 输出从第三个开始到第五个的字符
  7. print (str[2:]) # 输出从第三个开始的后的所有字符
  8. print (str * 2) # 输出字符串两次,也可以写成 print (2 * str)
  9. print (str + "TEST") # 连接字符串

执行以上程序会输出如下结果:

  1. Runoob
  2. Runoo
  3. R
  4. noo
  5. noob
  6. RunoobRunoob
  7. RunoobTEST

Python 使用反斜杠 \ 转义特殊字符,如果你不想让反斜杠发生转义,可以在字符串前面添加一个 r,表示原始字符串:

实例

  1. >>> print('Ru\noob')
  2. Ru
  3. oob
  4. >>> print(r'Ru\noob')
  5. Ru\noob
  6. >>>

另外,反斜杠(\)可以作为续行符,表示下一行是上一行的延续。也可以使用 """...""" 或者 '''...''' 跨越多行。

注意,Python 没有单独的字符类型,一个字符就是长度为1的字符串。

实例

  1. >>> word = 'Python'
  2. >>> print(word[0], word[5])
  3. P n
  4. >>> print(word[-1], word[-6])
  5. n P

与 C 字符串不同的是,Python 字符串不能被改变。向一个索引位置赋值,比如word[0] = 'm'会导致错误。

注意:

  • 1、反斜杠可以用来转义,使用r可以让反斜杠不发生转义。
  • 2、字符串可以用+运算符连接在一起,用*运算符重复。
  • 3、Python中的字符串有两种索引方式,从左往右以0开始,从右往左以-1开始。
  • 4、Python中的字符串不能改变。

List(列表)

List(列表) 是 Python 中使用最频繁的数据类型。

列表可以完成大多数集合类的数据结构实现。列表中元素的类型可以不相同,它支持数字,字符串甚至可以包含列表(所谓嵌套)。

列表是写在方括号 [] 之间、用逗号分隔开的元素列表。

和字符串一样,列表同样可以被索引和截取,列表被截取后返回一个包含所需元素的新列表。

列表截取的语法格式如下:

变量[头下标:尾下标]

索引值以 0 为开始值,-1 为从末尾的开始位置。

加号 + 是列表连接运算符,星号 * 是重复操作。如下实例:

实例

  1. #!/usr/bin/python3
  2. list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
  3. tinylist = [123, 'runoob']
  4. print (list) # 输出完整列表
  5. print (list[0]) # 输出列表第一个元素
  6. print (list[1:3]) # 从第二个开始输出到第三个元素
  7. print (list[2:]) # 输出从第三个元素开始的所有元素
  8. print (tinylist * 2) # 输出两次列表
  9. print (list + tinylist) # 连接列表

以上实例输出结果:

  1. ['abcd', 786, 2.23, 'runoob', 70.2]
  2. abcd
  3. [786, 2.23]
  4. [2.23, 'runoob', 70.2]
  5. [123, 'runoob', 123, 'runoob']
  6. ['abcd', 786, 2.23, 'runoob', 70.2, 123, 'runoob']

与Python字符串不一样的是,列表中的元素是可以改变的:

实例

  1. >>> a = [1, 2, 3, 4, 5, 6]
  2. >>> a[0] = 9
  3. >>> a[2:5] = [13, 14, 15]
  4. >>> a
  5. [9, 2, 13, 14, 15, 6]
  6. >>> a[2:5] = [] # 将对应的元素值设置为 []
  7. >>> a
  8. [9, 2, 6]

List 内置了有很多方法,例如 append()、pop() 等等,这在后面会讲到。

注意:

  • 1、List写在方括号之间,元素用逗号隔开。
  • 2、和字符串一样,list可以被索引和切片。
  • 3、List可以使用+操作符进行拼接。
  • 4、List中的元素是可以改变的。

Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:

如果第三个参数为负数表示逆向读取,以下实例用于翻转字符串:

实例

  1. def reverseWords(input):
  2. # 通过空格将字符串分隔符,把各个单词分隔为列表
  3. inputWords = input.split(" ")
  4. # 翻转字符串
  5. # 假设列表 list = [1,2,3,4],
  6. # list[0]=1, list[1]=2 ,而 -1 表示最后一个元素 list[-1]=4 ( 与 list[3]=4 一样)
  7. # inputWords[-1::-1] 有三个参数
  8. # 第一个参数 -1 表示最后一个元素
  9. # 第二个参数为空,表示移动到列表末尾
  10. # 第三个参数为步长,-1 表示逆向
  11. inputWords=inputWords[-1::-1]
  12. # 重新组合字符串
  13. output = ' '.join(inputWords)
  14. return output
  15. if __name__ == "__main__":
  16. input = 'I like runoob'
  17. rw = reverseWords(input)
  18. print(rw)

输出结果为:

runoob like I

Tuple(元组)

元组(tuple)与列表类似,不同之处在于元组的元素不能修改。元组写在小括号 () 里,元素之间用逗号隔开。

元组中的元素类型也可以不相同:

实例

  1. #!/usr/bin/python3
  2. tuple = ( 'abcd', 786 , 2.23, 'runoob', 70.2 )
  3. tinytuple = (123, 'runoob')
  4. print (tuple) # 输出完整元组
  5. print (tuple[0]) # 输出元组的第一个元素
  6. print (tuple[1:3]) # 输出从第二个元素开始到第三个元素
  7. print (tuple[2:]) # 输出从第三个元素开始的所有元素
  8. print (tinytuple * 2) # 输出两次元组
  9. print (tuple + tinytuple) # 连接元组

以上实例输出结果:

  1. ('abcd', 786, 2.23, 'runoob', 70.2)
  2. abcd
  3. (786, 2.23)
  4. (2.23, 'runoob', 70.2)
  5. (123, 'runoob', 123, 'runoob')
  6. ('abcd', 786, 2.23, 'runoob', 70.2, 123, 'runoob')

元组与字符串类似,可以被索引且下标索引从0开始,-1 为从末尾开始的位置。也可以进行截取(看上面,这里不再赘述)。

其实,可以把字符串看作一种特殊的元组。

实例

  1. >>> tup = (1, 2, 3, 4, 5, 6)
  2. >>> print(tup[0])
  3. 1
  4. >>> print(tup[1:5])
  5. (2, 3, 4, 5)
  6. >>> tup[0] = 11 # 修改元组元素的操作是非法的
  7. Traceback (most recent call last):
  8. File "<stdin>", line 1, in <module>
  9. TypeError: 'tuple' object does not support item assignment
  10. >>>

虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。

构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:

  1. tup1 = () # 空元组
  2. tup2 = (20,) # 一个元素,需要在元素后添加逗号

string、list 和 tuple 都属于 sequence(序列)。

注意:

  • 1、与字符串一样,元组的元素不能修改。
  • 2、元组也可以被索引和切片,方法一样。
  • 3、注意构造包含 0 或 1 个元素的元组的特殊语法规则。
  • 4、元组也可以使用+操作符进行拼接。

Set(集合)

集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。

基本功能是进行成员关系测试和删除重复元素。

可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

创建格式:

  1. parame = {value01,value02,...}
  2. 或者
  3. set(value)

实例

  1. #!/usr/bin/python3
  2. sites = {'Google', 'Taobao', 'Runoob', 'Facebook', 'Zhihu', 'Baidu'}
  3. print(sites) # 输出集合,重复的元素被自动去掉
  4. # 成员测试
  5. if 'Runoob' in sites :
  6. print('Runoob 在集合中')
  7. else :
  8. print('Runoob 不在集合中')
  9. # set可以进行集合运算
  10. a = set('abracadabra')
  11. b = set('alacazam')
  12. print(a)
  13. print(a - b) # a 和 b 的差集
  14. print(a | b) # a 和 b 的并集
  15. print(a & b) # a 和 b 的交集
  16. print(a ^ b) # a 和 b 中不同时存在的元素

以上实例输出结果:

  1. {'Zhihu', 'Baidu', 'Taobao', 'Runoob', 'Google', 'Facebook'}
  2. Runoob 在集合中
  3. {'b', 'c', 'a', 'r', 'd'}
  4. {'r', 'b', 'd'}
  5. {'b', 'c', 'a', 'z', 'm', 'r', 'l', 'd'}
  6. {'c', 'a'}
  7. {'z', 'b', 'm', 'r', 'l', 'd'}

Dictionary(字典)

字典(dictionary)是Python中另一个非常有用的内置数据类型。

列表是有序的对象集合,字典是无序的对象集合。两者之间的区别在于:字典当中的元素是通过键来存取的,而不是通过偏移存取。

字典是一种映射类型,字典用 { } 标识,它是一个无序的 键(key) : 值(value) 的集合。

键(key)必须使用不可变类型。

在同一个字典中,键(key)必须是唯一的。

实例

  1. #!/usr/bin/python3
  2. dict = {}
  3. dict['one'] = "1 - 菜鸟教程"
  4. dict[2] = "2 - 菜鸟工具"
  5. tinydict = {'name': 'runoob','code':1, 'site': 'www.runoob.com'}
  6. print (dict['one']) # 输出键为 'one' 的值
  7. print (dict[2]) # 输出键为 2 的值
  8. print (tinydict) # 输出完整的字典
  9. print (tinydict.keys()) # 输出所有键
  10. print (tinydict.values()) # 输出所有值

以上实例输出结果:

  1. 1 - 菜鸟教程
  2. 2 - 菜鸟工具
  3. {'name': 'runoob', 'code': 1, 'site': 'www.runoob.com'}
  4. dict_keys(['name', 'code', 'site'])
  5. dict_values(['runoob', 1, 'www.runoob.com'])

构造函数 dict() 可以直接从键值对序列中构建字典如下:

实例

  1. >>> dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
  2. {'Runoob': 1, 'Google': 2, 'Taobao': 3}
  3. >>> {x: x**2 for x in (2, 4, 6)}
  4. {2: 4, 4: 16, 6: 36}
  5. >>> dict(Runoob=1, Google=2, Taobao=3)
  6. {'Runoob': 1, 'Google': 2, 'Taobao': 3}
  7. >>>


 

另外,字典类型也有一些内置的函数,例如clear()、keys()、values()等。

注意:

  • 1、字典是一种映射类型,它的元素是键值对。
  • 2、字典的关键字必须为不可变类型,且不能重复。
  • 3、创建空字典使用 { }

Python数据类型转换

有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。

以下几个内置的函数可以执行数据类型之间的转换。这些函数返回一个新的对象,表示转换的值。

函数 描述

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)

将一个整数转换为一个八进制字符串

Python3 解释器

Linux/Unix的系统上,一般默认的 python 版本为 2.x,我们可以将 python3.x 安装在 /usr/local/python3 目录中。

安装完成后,我们可以将路径 /usr/local/python3/bin 添加到您的 Linux/Unix 操作系统的环境变量中,这样您就可以通过 shell 终端输入下面的命令来启动 Python3 。

  1. $ PATH=$PATH:/usr/local/python3/bin/python3 # 设置环境变量
  2. $ python3 --version
  3. Python 3.4.0

在Window系统下你可以通过以下命令来设置Python的环境变量,假设你的Python安装在 C:\Python34 下:

set path=%path%;C:\python34

交互式编程

我们可以在命令提示符中输入"Python"命令来启动Python解释器:

$ python3

执行以上命令后,出现如下窗口信息:

  1. $ python3
  2. Python 3.4.0 (default, Apr 11 2014, 13:05:11)
  3. [GCC 4.8.2] on linux
  4. Type "help", "copyright", "credits" or "license" for more information.
  5. >>>

在 python 提示符中输入以下语句,然后按回车键查看运行效果:

print ("Hello, Python!");

以上命令执行结果如下:

Hello, Python!

当键入一个多行结构时,续行是必须的。我们可以看下如下 if 语句:

  1. >>> flag = True
  2. >>> if flag :
  3. ... print("flag 条件为 True!")
  4. ...
  5. 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!

Python3 注释

确保对模块, 函数, 方法和行内注释使用正确的风格

Python中的注释有单行注释和多行注释:

Python中单行注释以 # 开头,例如::

  1. # 这是一个注释
  2. print("Hello, World!")

多行注释用三个单引号 ''' 或者三个双引号 """ 将注释括起来,例如:

1、单引号(''')

  1. #!/usr/bin/python3
  2. '''
  3. 这是多行注释,用三个单引号
  4. 这是多行注释,用三个单引号
  5. 这是多行注释,用三个单引号
  6. '''
  7. print("Hello, World!")

2、双引号(""")

  1. #!/usr/bin/python3
  2. """
  3. 这是多行注释,用三个双引号
  4. 这是多行注释,用三个双引号
  5. 这是多行注释,用三个双引号
  6. """
  7. print("Hello, World!")

Python3 运算符


什么是运算符?

本章节主要说明 Python 的运算符。

举个简单的例子:

4 + 5 = 9

例子中,4 和 5 被称为操作数,+ 称为运算符

Python 语言支持以下类型的运算符:

接下来让我们一个个来学习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次方
// 取整除 - 向下取接近商的整数
  1. >>> 9//2
  2. 4
  3. >>> -9//2
  4. -5

以下实例演示了Python所有算术运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 21
  3. b = 10
  4. c = 0
  5. c = a + b
  6. print ("1 - c 的值为:", c)
  7. c = a - b
  8. print ("2 - c 的值为:", c)
  9. c = a * b
  10. print ("3 - c 的值为:", c)
  11. c = a / b
  12. print ("4 - c 的值为:", c)
  13. c = a % b
  14. print ("5 - c 的值为:", c)
  15. # 修改变量 a 、b 、c
  16. a = 2
  17. b = 3
  18. c = a**b
  19. print ("6 - c 的值为:", c)
  20. a = 10
  21. b = 5
  22. c = a//b
  23. print ("7 - c 的值为:", c)

以上实例输出结果:

  1. 1 - c 的值为: 31
  2. 2 - c 的值为: 11
  3. 3 - c 的值为: 210
  4. 4 - c 的值为: 2.1
  5. 5 - c 的值为: 1
  6. 6 - c 的值为: 8
  7. 7 - c 的值为: 2

Python比较运算符

以下假设变量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所有比较运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 21
  3. b = 10
  4. c = 0
  5. if ( a == b ):
  6. print ("1 - a 等于 b")
  7. else:
  8. print ("1 - a 不等于 b")
  9. if ( a != b ):
  10. print ("2 - a 不等于 b")
  11. else:
  12. print ("2 - a 等于 b")
  13. if ( a < b ):
  14. print ("3 - a 小于 b")
  15. else:
  16. print ("3 - a 大于等于 b")
  17. if ( a > b ):
  18. print ("4 - a 大于 b")
  19. else:
  20. print ("4 - a 小于等于 b")
  21. # 修改变量 a 和 b 的值
  22. a = 5
  23. b = 20
  24. if ( a <= b ):
  25. print ("5 - a 小于等于 b")
  26. else:
  27. print ("5 - a 大于 b")
  28. if ( b >= a ):
  29. print ("6 - b 大于等于 a")
  30. else:
  31. print ("6 - b 小于 a")

以上实例输出结果:

  1. 1 - a 不等于 b
  2. 2 - a 不等于 b
  3. 3 - a 大于等于 b
  4. 4 - a 大于 b
  5. 5 - a 小于等于 b
  6. 6 - b 大于等于 a

Python赋值运算符

以下假设变量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() 两次:

  1. if (n := len(a)) > 10:
  2. print(f"List is too long ({n} elements, expected <= 10)")

以下实例演示了Python所有赋值运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 21
  3. b = 10
  4. c = 0
  5. c = a + b
  6. print ("1 - c 的值为:", c)
  7. c += a
  8. print ("2 - c 的值为:", c)
  9. c *= a
  10. print ("3 - c 的值为:", c)
  11. c /= a
  12. print ("4 - c 的值为:", c)
  13. c = 2
  14. c %= a
  15. print ("5 - c 的值为:", c)
  16. c **= a
  17. print ("6 - c 的值为:", c)
  18. c //= a
  19. print ("7 - c 的值为:", c)

以上实例输出结果:

  1. 1 - c 的值为: 31
  2. 2 - c 的值为: 52
  3. 3 - c 的值为: 1092
  4. 4 - c 的值为: 52.0
  5. 5 - c 的值为: 2
  6. 6 - c 的值为: 2097152
  7. 7 - c 的值为: 99864

Python位运算符

按位运算符是把数字看作二进制来进行计算的。Python中的按位运算法则如下:

下表中变量 a 为 60,b 为 13二进制格式如下:

  1. a = 0011 1100
  2. b = 0000 1101
  3. -----------------
  4. a&b = 0000 1100
  5. a|b = 0011 1101
  6. a^b = 0011 0001
  7. ~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所有位运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 60 # 60 = 0011 1100
  3. b = 13 # 13 = 0000 1101
  4. c = 0
  5. c = a & b # 12 = 0000 1100
  6. print ("1 - c 的值为:", c)
  7. c = a | b # 61 = 0011 1101
  8. print ("2 - c 的值为:", c)
  9. c = a ^ b # 49 = 0011 0001
  10. print ("3 - c 的值为:", c)
  11. c = ~a # -61 = 1100 0011
  12. print ("4 - c 的值为:", c)
  13. c = a << 2 # 240 = 1111 0000
  14. print ("5 - c 的值为:", c)
  15. c = a >> 2 # 15 = 0000 1111
  16. print ("6 - c 的值为:", c)

以上实例输出结果:

  1. 1 - c 的值为: 12
  2. 2 - c 的值为: 61
  3. 3 - c 的值为: 49
  4. 4 - c 的值为: -61
  5. 5 - c 的值为: 240
  6. 6 - c 的值为: 15

Python逻辑运算符

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

以上实例输出结果:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 10
  3. b = 20
  4. if ( a and b ):
  5. print ("1 - 变量 a 和 b 都为 true")
  6. else:
  7. print ("1 - 变量 a 和 b 有一个不为 true")
  8. if ( a or b ):
  9. print ("2 - 变量 a 和 b 都为 true,或其中一个变量为 true")
  10. else:
  11. print ("2 - 变量 a 和 b 都不为 true")
  12. # 修改变量 a 的值
  13. a = 0
  14. if ( a and b ):
  15. print ("3 - 变量 a 和 b 都为 true")
  16. else:
  17. print ("3 - 变量 a 和 b 有一个不为 true")
  18. if ( a or b ):
  19. print ("4 - 变量 a 和 b 都为 true,或其中一个变量为 true")
  20. else:
  21. print ("4 - 变量 a 和 b 都不为 true")
  22. if not( a and b ):
  23. print ("5 - 变量 a 和 b 都为 false,或其中一个变量为 false")
  24. else:
  25. print ("5 - 变量 a 和 b 都为 true")

以上实例输出结果:

  1. 1 - 变量 a 和 b 都为 true
  2. 2 - 变量 a 和 b 都为 true,或其中一个变量为 true
  3. 3 - 变量 a 和 b 有一个不为 true
  4. 4 - 变量 a 和 b 都为 true,或其中一个变量为 true
  5. 5 - 变量 a 和 b 都为 false,或其中一个变量为 false

Python成员运算符

除了以上的一些运算符之外,Python还支持成员运算符,测试实例中包含了一系列的成员,包括字符串,列表或元组。

运算符 描述 实例
in 如果在指定的序列中找到值返回 True,否则返回 False。 x 在 y 序列中 , 如果 x 在 y 序列中返回 True。
not in 如果在指定的序列中没有找到值返回 True,否则返回 False。 x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。

以下实例演示了Python所有成员运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 10
  3. b = 20
  4. list = [1, 2, 3, 4, 5 ]
  5. if ( a in list ):
  6. print ("1 - 变量 a 在给定的列表中 list 中")
  7. else:
  8. print ("1 - 变量 a 不在给定的列表中 list 中")
  9. if ( b not in list ):
  10. print ("2 - 变量 b 不在给定的列表中 list 中")
  11. else:
  12. print ("2 - 变量 b 在给定的列表中 list 中")
  13. # 修改变量 a 的值
  14. a = 2
  15. if ( a in list ):
  16. print ("3 - 变量 a 在给定的列表中 list 中")
  17. else:
  18. print ("3 - 变量 a 不在给定的列表中 list 中")

以上实例输出结果:

  1. 1 - 变量 a 不在给定的列表中 list 中
  2. 2 - 变量 b 不在给定的列表中 list 中
  3. 3 - 变量 a 在给定的列表中 list 中

Python身份运算符

身份运算符用于比较两个对象的存储单元

运算符 描述 实例
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所有身份运算符的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 20
  3. b = 20
  4. if ( a is b ):
  5. print ("1 - a 和 b 有相同的标识")
  6. else:
  7. print ("1 - a 和 b 没有相同的标识")
  8. if ( id(a) == id(b) ):
  9. print ("2 - a 和 b 有相同的标识")
  10. else:
  11. print ("2 - a 和 b 没有相同的标识")
  12. # 修改变量 b 的值
  13. b = 30
  14. if ( a is b ):
  15. print ("3 - a 和 b 有相同的标识")
  16. else:
  17. print ("3 - a 和 b 没有相同的标识")
  18. if ( a is not b ):
  19. print ("4 - a 和 b 没有相同的标识")
  20. else:
  21. print ("4 - a 和 b 有相同的标识")

以上实例输出结果:

  1. 1 - a 和 b 有相同的标识
  2. 2 - a 和 b 有相同的标识
  3. 3 - a 和 b 没有相同的标识
  4. 4 - a 和 b 没有相同的标识

is 与 == 区别:

is 用于判断两个变量引用对象是否为同一个, == 用于判断引用变量的值是否相等。

  1. >>>a = [1, 2, 3]
  2. >>> b = a
  3. >>> b is a
  4. True
  5. >>> b == a
  6. True
  7. >>> b = a[:]
  8. >>> b is a
  9. False
  10. >>> b == a
  11. True


Python运算符优先级

以下表格列出了从最高到最低优先级的所有运算符:

运算符 描述
** 指数 (最高优先级)
~ + - 按位翻转, 一元加号和减号 (最后两个的方法名为 +@ 和 -@)
* / % // 乘,除,求余数和取整除
+ - 加法减法
>> << 右移,左移运算符
& 位 'AND'
^ | 位运算符
<= < > >= 比较运算符
== != 等于运算符
= %= /= //= -= += *= **= 赋值运算符
is is not 身份运算符
in not in 成员运算符
not and or 逻辑运算符

以下实例演示了Python所有运算符优先级的操作:

实例(Python 3.0+)

  1. #!/usr/bin/python3
  2. a = 20
  3. b = 10
  4. c = 15
  5. d = 5
  6. e = 0
  7. e = (a + b) * c / d #( 30 * 15 ) / 5
  8. print ("(a + b) * c / d 运算结果为:", e)
  9. e = ((a + b) * c) / d # (30 * 15 ) / 5
  10. print ("((a + b) * c) / d 运算结果为:", e)
  11. e = (a + b) * (c / d) # (30) * (15/5)
  12. print ("(a + b) * (c / d) 运算结果为:", e)
  13. e = a + (b * c) / d # 20 + (150/5)
  14. print ("a + (b * c) / d 运算结果为:", e)

以上实例输出结果:

  1. (a + b) * c / d 运算结果为: 90.0
  2. ((a + b) * c) / d 运算结果为: 90.0
  3. (a + b) * (c / d) 运算结果为: 90.0
  4. a + (b * c) / d 运算结果为: 50.0

and 拥有更高优先级:

实例

  1. x = True
  2. y = False
  3. z = False
  4. if x or y and z:
  5. print("yes")
  6. else:
  7. print("no")

以上实例输出结果:

yes
注意:Pyhton3 已不支持 <> 运算符,可以使用 != 代替,如果你一定要使用这种比较运算符,可以使用以下的方式:
  1. >>> from __future__ import barry_as_FLUFL
  2. >>> 1 <> 2
  3. True

Python3 数字(Number)

Python 数字数据类型用于存储数值。

数据类型是不允许改变的,这就意味着如果改变数字数据类型的值,将重新分配内存空间。

以下实例在变量赋值时 Number 对象将被创建:

  1. var1 = 1
  2. var2 = 10

您也可以使用del语句删除一些数字对象的引用。

del语句的语法是:

del var1[,var2[,var3[....,varN]]]

您可以通过使用del语句删除单个或多个对象的引用,例如:

  1. del var
  2. 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都是浮点型。

我们可以使用十六进制和八进制来代表整数:

  1. >>> number = 0xA0F # 十六进制
  2. >>> number
  3. 2575
  4. >>> number=0o37 # 八进制
  5. >>> number
  6. 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
  • Python支持复数,复数由实数部分和虚数部分构成,可以用a + bj,或者complex(a,b)表示, 复数的实部a和虚部b都是浮点型。


Python 数字类型转换

有时候,我们需要对数据内置的类型进行转换,数据类型的转换,你只需要将数据类型作为函数名即可。

  • int(x) 将x转换为一个整数。

  • float(x) 将x转换到一个浮点数。

  • complex(x) 将x转换到一个复数,实数部分为 x,虚数部分为 0。

  • complex(x, y) 将 x 和 y 转换到一个复数,实数部分为 x,虚数部分为 y。x 和 y 是数字表达式。

以下实例将浮点数变量 a 转换为整数:

  1. >>> a = 1.0
  2. >>> int(a)
  3. 1

Python 数字运算

Python 解释器可以作为一个简单的计算器,您可以在解释器里输入一个表达式,它将输出表达式的值。

表达式的语法很直白: +, -, * 和 /, 和其它语言(如Pascal或C)里一样。例如:

  1. >>> 2 + 2
  2. 4
  3. >>> 50 - 5*6
  4. 20
  5. >>> (50 - 5*6) / 4
  6. 5.0
  7. >>> 8 / 5 # 总是返回一个浮点数
  8. 1.6

注意:在不同的机器上浮点运算的结果可能会不一样。

在整数除法中,除法 / 总是返回一个浮点数,如果只想得到整数的结果,丢弃可能的分数部分,可以使用运算符 // :

  1. >>> 17 / 3 # 整数除法返回浮点型
  2. 5.666666666666667
  3. >>>
  4. >>> 17 // 3 # 整数除法返回向下取整后的结果
  5. 5
  6. >>> 17 % 3 # %操作符返回除法的余数
  7. 2
  8. >>> 5 * 3 + 2
  9. 17

注意:// 得到的并不一定是整数类型的数,它与分母分子的数据类型有关系。

  1. >>> 7//2
  2. 3
  3. >>> 7.0//2
  4. 3.0
  5. >>> 7//2.0
  6. 3.0
  7. >>>

等号 = 用于给变量赋值。赋值之后,除了下一个提示符,解释器不会显示任何结果。

  1. >>> width = 20
  2. >>> height = 5*9
  3. >>> width * height
  4. 900

Python 可以使用 ** 操作来进行幂运算:

  1. >>> 5 ** 2 # 5 的平方
  2. 25
  3. >>> 2 ** 7 # 2的7次方
  4. 128

变量在使用前必须先"定义"(即赋予变量一个值),否则会出现错误:

  1. >>> n # 尝试访问一个未定义的变量
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. NameError: name 'n' is not defined

不同类型的数混合运算时会将整数转换为浮点数:

  1. >>> 3 * 3.75 / 1.5
  2. 7.5
  3. >>> 7.0 / 2
  4. 3.5

在交互模式中,最后被输出的表达式结果被赋值给变量 。例如:

  1. >>> tax = 12.5 / 100
  2. >>> price = 100.50
  3. >>> price * tax
  4. 12.5625
  5. >>> price + _
  6. 113.0625
  7. >>> round(_, 2)
  8. 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
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/420537
推荐阅读
相关标签
  

闽ICP备14008679号