1、int类型
int类型的数据是没有长度限制的,它的最大长度只与计算机的内存有关。
1 bin(i) 返回二进制表示结果,2 hex(i) 十六进制,3 int(i) 整数(如果x是浮点数就会返回其整数部分,4 oct(i) 八进制,5 int(s,base)将字符串转换为整数.幂可以用**实现(10**5,2**4).内置的float与str类型都支持到整数的转换。6 chr() 将数字转换成字符,7 ord() 将字符转换成ASCII码;8 round() 函数对值进行四舍五入。整数和浮点数相加结果是浮点型。
2、简单比较两个float是否相等
defequal_float(a,b):return abs(a-b)<=sys.float_info.epsilon
3、复数
复数的表示需在虚部后加一个j,如z=3.5+2j,其中实部和虚部可分别用z.real,z.imag取得。专用函数z.conjugate()可以反转虚部的符号。
4、Decimal,
特点:精度高,但计算速度比float慢,使用前需引进模块。
a=decimal.Decimal(5555)或a=decimal.Decimal("555.555")
5、字符串
对字符串内使用的单引号或者双引号,如果与最外层的相同则需要进行转义,如果不同则可以直接使用。
字符串转义:
\newline 忽略换行,
\\ 反斜杠,
\' 单引号,
\" 双引号,
\a 蜂鸣,
\b 退格,
\f 走纸,
\n 换行,
\r 回车,
\t 制表符。
6、负索引
即从-1开始从末尾倒数。
7、字符串的分片操作(seq[start:end];seq[start:end:step]
seq[start:end],表示两个位置之间的字符(区间为左闭右开,即[start,end)),无start则默认为0,无end则默认为len(seq),
seq[:]表示整个字符串。
字符串的追加可用+=,但并不是特别高效,连接大量字符串可用seq.join()。
"xx".join(seq)则可以将xx依次插入每两个seq元素之间,形成一个str。
seq[star:end:step]与前一种类似,但是step不能为空,且必须大于0,即步长。
8、reversed()反转一个集合内元素的排列顺序。
9、字符查找(index(),find())
find()找到目标时返回该字符在字符串中的索引位置,没找到则返回-1;index()找到时也返回索引位置,没找到则产生一个ValueError异常。函数前边加r的(rfind(),rindex())表示逆序开始查找。
find()、index都可接受至多两个可选参数(起点、终点):
str.find("m",6)=str[6:].find("m")
str.find("m",2,5)=str[2:5].find("m")
类似的函数还有:str.count(),str.endswith(),str.startswith()。
10、字符串分割partition(),rpartition(),split(),strip()
patition()将字符串分割为三段:关键字前,关键字,关键字后.
split()将字符串以关键字为分割点进行分割(结果不包含关键字)
strip()将字符串的首尾空格去掉,如果给了参数,就去掉首尾的参数,但参数必须是位于字符串的首尾,不然去不掉.分支函数lstrip(),rstrip()为去掉左边或者右边的末端空格或字符.
11、字符串的格式化 str.format()
1>"a{0}cd{1}".format("one","two")。被替换字符用{}包围,用数字格式表示时0,1依次表示format内给定参数的索引位置。如要想在替换后的字符串中出现花括号,则需在原字符串中进行复写或三写({{0}},{{{1}}})。对于3.1以上的python,{}内可以为空,不写索引值,系统会默认次数下去为空的{}索引值为0,1,2,3...
这种替换方法还可用来解决字符串与数字连接会产生TypeError异常的问题。
2>"a{who} was {0}".format(12,who="she") 字段名替代索引方法如左,但如果同时存在字段名和索引时,索引位置须放置在索引之前,如样例中不能将0改成1而把对应的参数12放在第二位。
3>对于一个集合(如:stock=["a","b","c"])可用:"{0[1]}{0[2]}".format(stock)
对于一个字典(如d=dic(a1="xx",a2="xxx")可用:"{0[a1]}{0[a2]}".format(d) 或者:"{a1}{a2}".format(**d) **在此处为映射拆分操作符,对于已经赋值的变量也可结合内置的locals()函数以相似的方法达成替换,c="xx";d=34;"{c}ad{d}".format(**locals())。
4>格式转换(r,s,a)用法:{0!r}
s-强制使用字符串格式,r-强制使用表象形式,a-强制使用表象形式(只限于ASCII字符)
5>字符串格式规约(样:"{0:*>10.25}"):以冒号开始,接着为充填字符(*),然后为对齐字符(>右对齐,<左对齐,^居中对齐),10为最小宽度,25为最大宽度,最大宽度前用"."引导。所有参数都是可选的,但如果指定了充填符就必须同时指定一个对齐符(对齐符可单独出现,结果以空格充填)
>整数格式规约(样:"{0:0^+#15X):与字符的大致相同,+为可选,位于对齐与最小宽度之间(表示必须输出正负号,还有-表示只用输出负号,空格表示正数输出空格负数输出负号),#位于最小宽度之前,用于输入当前数据类型,#也可以用0替换(表示用0进行充填,此充填法可不指定对齐方式);X表示输出数据转换类型(b二进制,o八进制,x小写十六进制,X大写十六进制,d十进制,c输出整数对应的Unicode字符,n表示场所敏感输出方式: import locale
locale.setlocale(locale.LC_ALL,"C") #C为场所,也可用en_US.UTF-8替换
c="{0:n}".format(55)
)。整数规约没有最大宽度!
>小数格式规约:与整数一样,但可以在最小宽度后加个以"."引导的整数来限定小数的位数。数据类型转换处可用:e,E指数形式,f标准浮点形式,g通常格式,%百分数形式。
tips:输出平方的上标 N\{SUPERSCRIPT TWO},右箭头:\N{RIGHTWARDS ARROW}
12、字符串操作函数
1 s.strip(chars)见上;2 s.find(x,start,end)见上;3 s.index(x.start,end)见上;4 s.format()见上;5 s.partition(x)见上;6 s.replace(x,y,n) 用y替换x,可选n表示最多替换n次;7 s.split(x,n) 最多分割n次,s.rsplit()从右边开始分割;8 s.splitlines(f) 返回在行终结符处进行分割产生的列表,并剥离行终结符(除非f为True);9 s.count(x,start,end) 计数;10 s.join(seq) 返回seq的每个项都以s连接起来的结果,s可以为空;11 s.capitalize() 将字符串首字母大写;12 s.lower() 将s中的字符变为小写;13 s.upper() 返回大写化版本;14 s.title() 将每个单词的首字母大写;15 s.swapcase() 将大写变小写,小写变大写;16 s.islower() 如果s至少有一个可小写的字符且所有可小写的字符都是小写则返回True;17 s.isupper() 如果s至少有一个可大写的字符且所有可大写的字符都是大写则返回True;18 s.istitle() 如果s是一个非空的首字母大写字符串,则返回True;19 s.zfill(w) 返回s的副本,如果比w短,从开始处用0补充,使长度和w一样;20 s.center(width,char) 返回一个以s为中心长度为width的字符串,如果有空余则用可选参数char或空格进行填充,如width