一、Python 数字(Number)
Python 数字数据类型用于存储数值。
数据类型是不允许改变的,这就意味着如果改变数字数据类型的值,将重新分配内存空间。
python中数字有四种类型:整数、布尔型、浮点数和复数。
1.int (整数), 如 1, 只有一种整数类型 int,表示为长整型,没有 python2 中的 Long。
2.bool (布尔), 如 True。
3.float (浮点数), 如 1.23、3E-2
4.complex (复数), 如 1 + 2j、 1.1 + 2.2j
内置的 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'>
数学函数
- 直接访问的内置函数
abs(x) 返回数字的绝对值,如abs(-10) 返回 10
cmp(x, y) 如果 x < y 返回 -1, 如果 x == y 返回 0, 如果 x > y 返回 1。 Python 3 已废弃 。使用 使用 (x>y)-(x<y) 替换。
max(x1, x2,...) 返回给定参数的最大值,参数可以为序列。
min(x1, x2,...) 返回给定参数的最小值,参数可以为序列。
round(x [,n]) 返回浮点数x的四舍五入值,如给出n值,则代表舍入到小数点后的位数。 x -- 需要四舍五入的数字表达式 n -- 表示从小数点位数,默认值为 0。例:round(80.264, 2))
- 需要导入 math 模块,通过静态对象调用该方法。
ceil(x) 返回数字的上入整数,如math.ceil(4.1) 返回 5
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
modf(x) 返回x的小数部分与整数部分(以浮点型表示)。
pow(x, y) x**y 运算后的值,方法返回 x^y(x的y次方)的值。
sqrt(x) 返回数字x的平方根。
注意:
1.Python fabs() 与 abs() 区别
fabs() 函数只适用于 float 和 integer 类型,而 abs() 也适用于复数。
2.实际使用中发现round函数并不总是如上所说的四舍五入
print ("round(2.355, 2) : ", round(2.355, 2))
因为该函数对于返回的浮点数并不是按照四舍五入的规则来计算,而会收到计算机表示精度的影响。
随机数函数
随机数可以用于数学,游戏,安全等领域中,还经常被嵌入到算法中,用以提高算法效率,并提高程序的安全性。
Python包含以下常用随机数函数:
不能直接访问的,需要导入 random 模块,然后通过 random 静态对象调用该方法。
choice(seq)
方法返回一个列表,元组或字符串的随机项。比如random.choice(range(10)),从0到9中随机挑选一个整数。
randrange ([start,] stop [,step])
从指定范围内,按指定基数递增的集合中获取一个随机数。step -- 指定递增基数,缺省值为1;
start -- 指定范围内的开始值,包含在范围内;
stop -- 指定范围内的结束值,不包含在范围内。
random()
随机生成下一个实数,它在[0,1)范围内。
seed([x])
方法改变随机数生成器的种子,可以在调用其他随机模块函数之前调用此函数
如果你不了解其原理,你不必特别去设定seed,Python会帮你选择seed。
shuffle(lst)
将序列的所有元素随机排序
uniform(x, y)
随机生成下一个实数,它在[x,y]范围内。
x -- 随机数的最小值。
y -- 随机数的最大值。
返回一个浮点数。
三角函数
Python包括以下三角函数:
不能直接访问的,需要导入 math 模块,然后通过 math 静态对象调用该方法。
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
radians(x) 将角度转换为弧度
数学常量
pi 数学常量 pi(圆周率,一般以π来表示)
e 数学常量 e,e即自然常数(自然常数)。
笔记
-
/
除法计算结果是浮点数,即使是两个整数恰好整除,结果也是浮点数。 -
//
称为地板除,两个整数的除法仍然是整数。 - isinstance 和 type 的区别在于:
type()
不会认为子类是一种父类类型。
isinstance()
会认为子类是一种父类类型:主要用于判断 A 类是否继承于 B 类 - 在 Python2 中是没有布尔型的,它用数字 0 表示 False,用 1 表示 True。到 Python3 中,把 True 和 False 定义成关键字了,但它们的值还是 1 和 0,它们可以和数字相加。
二、Python 字符串(String)
Python中的字符串用 单引号 ' 或 双引号 " 括起来。
字转义字符
使用反斜杠 \ 转义特殊字符
Python还允许用r''表示''内部的字符串默认不转义print( r'\n' )
.
\(在行尾时)
续行符
\n
换行
\r
回车
\t
横向制表符
.
.
.
字符串运算符
变量a值为字符串 "Hello",b变量值为 "Python
+ 字符串连接 a + b 输出结果: HelloPython
* 重复输出字符串 a*2 输出结果:HelloHello
[] 通过索引获取字符串中字符 a[1] 输出结果 e
[ : ] 截取字符串中的一部分,遵循左闭右开原则,str[0,2] 是不包含第 3 个字符的。 a[1:4] 输出结果 ell
in 成员运算符 - 如果字符串中包含给定的字符返回 True 'H' in a 输出结果 True
not in 成员运算符 - 如果字符串中不包含给定的字符返回 True 'M' not in a 输出结果 True
字符串的截取的语法格式如下:
- 变量[头下标:尾下标]
索引值以 0 为开始值,-1 为从末尾的开始位置。 - [0:-1]输出第一个到倒数第二个的所有字符 不包括-1
[2:5] 输出从第三个开始到第五个的字符
[2:] 输出从第三个开始的后的所有字符
[:]如果a,b均不填写,默认取全部字符。
如果a>=b, 默认输出为空 - 与 C 字符串不同的是,Python 字符串不能被改变。向一个索引位置赋值,比如word[0] = 'm'会导致错误。
- [::2] 表示的是从头到尾,步长为2。第一个冒号两侧的数字是指截取字符串的范围,第二个冒号后面是指截取的步长。
- 字符串的分割还有partition()这种方式。
partition(sep) --> (head,sep,tail)
从左向右遇到分隔符把字符串分割成两部分,返回头、分割符、尾三部分的三元组。如果没有找到分割符,就返回头、尾两个空元素的三元组。
字符串格式化
print ("我叫 %s 今年 %d 岁!" % ('小明', 10))
%c 格式化字符及其ASCII码
%s 格式化字符串
%d 格式化整数
%u 格式化无符号整型
%o 格式化无符号八进制数
%x 格式化无符号十六进制数
%X 格式化无符号十六进制数(大写)
%f 格式化浮点数字,可指定小数点后的精度
%e 用科学计数法格式化浮点数
%E 作用同%e,用科学计数法格式化浮点数
%g %f和%e的简写:%g 是自动选择输出格式的 %g 用于打印数据时,会去掉多余的零,至多保留六位有效数字。
%G %f 和 %E 的简写
%p 用十六进制数格式化变量的地址
Python三引号
python三引号允许一个字符串跨多行,字符串中可以包含换行符、制表符以及其他特殊字符。
用例,当你需要一块HTML或者SQL时,这时用字符串组合,特殊字符串转义将会非常的繁琐。
para_str = """这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( \t )。
也可以使用换行符 [ \n ]。
"""
print (para_str)
以上实例执行结果为:
这是一个多行字符串的实例
多行字符串可以使用制表符
TAB ( )。
也可以使用换行符 [
]。
笔记
- Python 没有单独的字符类型,一个字符就是长度为 1 的字符串。
字符串内建函数
语法: str.xx() str.capitalize()
Python 的字符串常用内建函数如下:
1
capitalize()
将字符串的第一个字母变成大写,其他字母变小写。
2
center(width, fillchar)
返回一个指定的宽度 width 居中的字符串。
如果 width 小于字符串宽度直接返回字符串,不会截断。
fillchar 为填充的字符,默认为空格,只能是单个字符。
3
count(str, start = 0,end=len(string))
返回 str 在 string 里面出现的次数,如果 start 或者 end 指定则返回指定范围内 str 出现的次数。 start默认第一个字符索引值为0。end默认为字符串的最后一个位置。
4
decode(encoding="utf-8", errors="strict")
以指定的编码格式解码 bytes 对象。默认编码为 'utf-8'。
errors -- 设置不同错误的处理方案。默认为 'strict',意为编码错误引起一个UnicodeError。 其他可能得值有 'ignore', 'replace', 'xmlcharrefreplace', 'backslashreplace' 以及通过 codecs.register_error() 注册的任何值。
Python3 中没有 decode 方法,但我们可以使用 bytes 对象的 decode() 方法来解码给定的 bytes 对象,这个 bytes 对象可以由 str.encode() 来编码返回。
5
encode(encoding='UTF-8',errors='strict')
以 encoding 指定的编码格式编码字符串,如果出错默认报一个ValueError 的异常,除非 errors 指定的是'ignore'或者'replace'
6
endswith(suffix, beg=0, end=len(string))
检查字符串是否以 obj 结束,如果beg 或者 end 指定则检查指定的范围内是否以 obj 结束,如果是,返回 True,否则返回 False.
7
expandtabs(tabsize=8)
把字符串 string 中的 tab 符号转为空格,tab 符号默认的空格数是 8 。
8
find(str, beg=0 end=len(string))
检测 str 是否包含在字符串中,如果指定范围 beg 和 end ,则检查是否包含在指定范围内,如果包含返回开始的索引值,否则返回-1
9
index(str, beg=0, end=len(string))
跟find()方法一样,只不过如果str不在字符串中会报一个异常.
10
isalnum()
如果字符串至少有一个字符并且所有字符都是字母或数字则返 回 True,否则返回 False
11
isalpha()
如果字符串至少有一个字符并且所有字符都是字母则返回 True, 否则返回 False
12
isdigit()
如果字符串只包含数字则返回 True 否则返回 False..
13
islower()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是小写,则返回 True,否则返回 False
14
isnumeric()
如果字符串中只包含数字字符,则返回 True,否则返回 False
15
isspace()
如果字符串中只包含空白,则返回 True,否则返回 False.
16
istitle()
如果字符串是标题化的(见 title())则返回 True,否则返回 False
17
isupper()
如果字符串中包含至少一个区分大小写的字符,并且所有这些(区分大小写的)字符都是大写,则返回 True,否则返回 False
18
join(seq)
以指定字符串作为分隔符,将 seq 中所有的元素(的字符串表示)合并为一个新的字符串
19
len(string)
返回字符串长度
20
ljust(width[, fillchar])
返回一个原字符串左对齐,并使用 fillchar 填充至长度 width 的新字符串,fillchar 默认为空格。
21
lower()
转换字符串中所有大写字符为小写.
22
lstrip()
截掉字符串左边的空格或指定字符。
23
maketrans()
创建字符映射的转换表,对于接受两个参数的最简单的调用方式,第一个参数是字符串,表示需要转换的字符,第二个参数也是字符串表示转换的目标。
24
max(str)
返回字符串 str 中最大的字母。
25
min(str)
返回字符串 str 中最小的字母。
26
replace(old, new [, max])
把 将字符串中的 str1 替换成 str2,如果 max 指定,则替换不超过 max 次。
27
rfind(str, beg=0,end=len(string))
类似于 find()函数,不过是从右边开始查找.
28
rindex( str, beg=0, end=len(string))
类似于 index(),不过是从右边开始.
29
rjust(width,[, fillchar])
返回一个原字符串右对齐,并使用fillchar(默认空格)填充至长度 width 的新字符串
30
rstrip()
删除字符串字符串末尾的空格.
31
split(str="", num=string.count(str))
num=string.count(str)) 以 str 为分隔符截取字符串,如果 num 有指定值,则仅截取 num 个子字符串
32
splitlines([keepends])
按照行('\r', '\r\n', \n')分隔,返回一个包含各行作为元素的列表,如果参数 keepends 为 False,不包含换行符,如果为 True,则保留换行符。
33
startswith(substr, beg=0,end=len(string))
检查字符串是否是以指定子字符串 substr 开头,是则返回 True,否则返回 False。如果beg 和 end 指定值,则在指定范围内检查。
34
strip([chars])
在字符串上执行 lstrip()和 rstrip()
35
swapcase()
将字符串中大写转换为小写,小写转换为大写
36
title()
返回"标题化"的字符串,就是说所有单词都是以大写开始,其余字母均为小写(见 istitle())
37
translate(table, deletechars="")
根据 str 给出的表(包含 256 个字符)转换 string 的字符, 要过滤掉的字符放到 deletechars 参数中
38
upper()
转换字符串中的小写字母为大写
39
zfill (width)
返回长度为 width 的字符串,原字符串右对齐,前面填充0
40
isdecimal()
检查字符串是否只包含十进制字符,如果是返回 true,否则返回 false。
三、Python 列表(List)
列表是写在方括号 [] 之间、用逗号分隔开的元素列表。
列表截取的语法格式如下:
变量[头下标:尾下标]
加号 + 是列表连接运算符,星号 * 是重复操作。
与Python字符串不一样的是,列表中的元素是可以改变的:
demo[索引:索引:步长] 切片得到的是一个新列表
demo[1::2] # 2 就是步长 意思是从索引为 1 的元素开始 每隔2个元素取一次元素
四、Python 元组(Tuple)
元组(tuple)与列表类似,不同之处在于元组的元素不能修改。元组写在小括号 () 里,元素之间用逗号隔开。
虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表。
构造包含 0 个或 1 个元素的元组比较特殊,所以有一些额外的语法规则:
tup1 = () # 空元组
tup2 = (20,) # 一个元素,需要在元素后添加逗号。
string、list和tuple都属于sequence(序列)。
五、Python集合(Set)
集合(set)是由一个或数个形态各异的大小整体组成的,构成集合的事物或对象称作元素或是成员。
基本功能是进行成员关系测试和删除重复元素。
可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。
set可以进行集合运算
函数返回多个值的时候,是以元组的方式返回的。
python中的函数还可以接收可变长参数,比如以 "*" 开头的的参数名,会将所有的参数收集到一个元组上。
六、Python字典(Dictionary)
字典(dictionary)是Python中另一个非常有用的内置数据类型。
字典是一种映射类型,字典用"{ }"标识,它是一个无序的键(key) : 值(value)对集合。
键(key)必须使用不可变类型。
在同一个字典中,键(key)必须是唯一的。
字典类型也有一些内置的函数,例如clear()、keys()、values()等。
python中的字典是使用了一个称为散列表(hashtable)的算法(不具体展开),
其特点就是:不管字典中有多少项,in操作符花费的时间都差不多。
如果把一个字典对象作为for的迭代对象,那么这个操作将会遍历字典的键
key不一定是 string类型,所以 用+ 号会出问题
输出 dict 的键值对,可直接用 items() 函数:
for k,v in dict1.items():
print(k,":",v)
dict(d)创建一个字典。d 不一定是一个序列 (key,value)元组。
元素为元组的列表/元素为元组的集合/元素为列表的列表/元素为元组的元组
set, dictionary 无序的对象集合