Number类型


整数与浮点数


## python2.7 
a = 123848488483993932002093939L ## 要加L,py2.7有长整型
b = 23.03
c = 10 / 4 ## 2
d = 10 / 4.0 ## 2.5
e = 10 // 4 ## 2
f = 10 // 4.0 ## 2.0

## python3.5
a = 1238484884839939320020939393839303 ## 不需要加L,python3.x是属于单个整数类型,不区分长整型
b = 29.90
c = 10 / 4 ## 2.5
d = 10 / 4.0 ## 2.5
e = 10 // 4 ## 2
f = 10 // 4.0 ## 2.0


Boolean,只有两个值:True && False


a = False
b = True


十进制转16进制、8进制、2进制


num = 29  ## 10进制
## 转16进制
hex(num) ## 0x1d

## 转8进制
oct(num) ## 0o35

## 转2进制
bin(num) ## 0b11101


16进制、8进制、2进制转十进制


## 16进制转10进制
str_hex = r'0x1d'
int(str_hex,base = 16)

## 8进制转10进制
str_oct = r'0o35'
int(str_oct,base = 8)

## 2进制转10进制
str_bin = r'0b11101'
int(str_bin,base = 2)

Sequence类型簇


序列类型簇



  • 字符串String
  • 元组Tuple
  • 列表List


基本操作符



  • A[index]:获取序列第index个元素,index取值从0开始
  • A[index1:index2]:切片操作,获取序列中index1到index2-1的子序列
  • A in B:判断序列B是否有A,如果有返回True,否则返回False
  • A not in B:判断序列B是否没有A,如果没有返回True,否则返回False
  • A + B :将序列A和序列B合并并组成一个新的序列返回
  • A * number :将序列A重复拼接number次并将拼接后新组成的序列返回
  • A == B:序列A与序列B的值和长度都相等


序列比较cmp原理(A > B or A < B)



  • 如果比较的元素是同类型的,则比较其值,返回结果。
  • 如果两个元素不是同一种类型,则检查它们是否是数字。

    • 如果是数字,执行必要的数字强制类型转换,然后比较。
    • 如果有一方的元素是数字,则另一方的元素"大"(数字是"最小的")
    • 否则,通过类型名字的字母顺序进行比较。

  • 如果有一个列表首先到达末尾,则另一个长一点的列表"大"。
  • 如果我们用尽了两个列表的元素而且所 有元素都是相等的,那么结果就是个平局,就是说返回一个 0

String类型


String是由零个或者多个字符组成的有限序列,通常以串的整体作为操作对象,字符串以引号包含标识


## 字符串定义
a = 'single' ## 单引号表示
b = "double" ## 双引号表示
c = """...spam...""" ## 三引号表示
d = '''...spam...''' ## 三引号表示

e = "s\tp\na\0m" ## 转义序列
f = r"C:\new\test.spm" ## raw 字符串,即用r禁用转义字符
bs = b'sp\x01am' ## 字节字符串
us = u"中文" ## Unicode字符串

如果字符串包含中文,应当声明为unicode字符串


字符串格式化表达式


## 格式化表达式:"...%s..." % (values) Or "...%(keyname)s..." % {keyname:keyvalue}
>>> "this is my %s" % ('name')
'this is my name'

>>> "this is my %(name)s" % {'name':'xiao'}
'this is my xiao'

## 格式化方法调用:"...{}...".format(values) Or "...{keyname1}...".format(keyname1=value1)
>>> "my name is {}".format('xiaokunliu')
'my name is xiaokunliu'

>>> "this is my {firstname},and {lastname}".format(firstname="xiaokun",lastname="liu")
'this is my xiaokun,and liu'


字符串格式化结构:%[(keyname)][flags][width][.precision]typecode


## keyname:字典对应索引的keyname
>>> '%(name)s' % {'name':'xiaokun'}
'xiaokun'

## flags:格式化符号(-、+、space空格键<sp>、#、0、m.n)
## -:左对齐;
## +:对正数输出正值符号;
## m.n:m是显示最小总宽度,n是小数点后的位数;
## #:在8进制数前面显示0,16进制前面显示"0x"或者"0X"
## 0:数字大小不足m.n的要求时用0补位;
## <sp>:数字大小不足m.n的要求时用空格补位;
x = 1.23456789
>>> "%-6.2f,%+3.4f,%#2.3f,%06.9f,% 3.9f" % (x,x,x,x,x)
'1.23 ,+1.2346,1.235,1.234567890, 1.234567890'

## width:指定显示字符串的宽度
>>> '%−6.2f' % x
'1.23 '
'
## .precision:整数格式化为字符串的时候需要保留的小数位数
>>> '%.3f' % x
'1.235'

## typecode:格式化符号
%s String (or any object’sstr(X)string)
%r Same ass, but usesrepr, not str
%c Character (int or str)
%d Decimal (base-10 integer)
%i Integer
%u Same asd(obsolete: no longer unsigned)
%o Octal integer (base 8)
%x Hex integer (base 16)
%X Same asx, but with uppercase letters
%e Floating point with exponent, lowercase
%E Same ase, but uses uppercase letters
%f Floating-point decimal
%F Same asf, but uses uppercase letters
%g Floating-point e or f
%G Floating-point E or F
%% Literal%(coded as%%)

Tuple类型


定义



  • 用圆括号表示,在不同元素之间以逗号隔开
  • Tuple大小以及其中的元素在初始化后不能修改
  • Tuple比可修改的List操作速度快
  • 用途;可以用于定义一组常量集并用于不断读取


简单示例


## 定义
>>> tuple1 = ('you',283,93,'English',4,5.6)

## 读取
>>> tuple1[3]

## 截取子元组
>>> subTuple = tuple1[3:]

## 可以对元组变量重新赋值,注意是元组变量不是元组对象
>>> tuple1 = tuple1 + (2,3,'playing')

## 获取长度
>>> len(tuple1)

## 不能修改
>>> tuple1[2] = "update" ### 这里将发生错误
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment

## 元素可重复
>>> tuple1 = tuple1 * 2

List类型


定义



  • 使用中括号表示,即[],不同元素之间以逗号隔开
  • List大小和其中的元素在初始化后可以被再次修改
  • 用途:对于定义的一组数据集,要求能够进行增删改查操作


简单示例


## 定义
>>> color_list = ['green','red','pink','blue','black','white']

## 读取元素
>>> color_list[2]

## 截取子列表
>>> color_list[3:]

## 修改指定序列的内容
>>> color_list[2] = "update_pink"

## 获取长度
>>> len(color_list)

## 元素遍历
>>> for color in color_list:
... print color
...

## 排序,排序后本身的color_list不变
>>> sorted_color_list = sorted(color_list)

## 求和
>>> num_list = [3.4,5,6,3,5.7,12,27,32]
>>> sum(num_list),'%i' % sum(num_list) '%.2f' % sum(num_list)

## 以指定的方式排序 list.sort(fn = None,key = None,reverse = False)
>>> num_list = [29,39,4,23,42,13,19,21]
>>> num_list.sort() ## 改变list对象本身
>>> sorted(num_list) ## 返回一个排序后的list对象,不改变num_list

## 按照key值排序
>>> key_list = [('name':3),('age':10),('num':23),('key':24)]
>>> key_list.sort(key = lambda x:x[1])

## 倒序排序
>>> key_list.sort(reverse = True)

## 正向排序
>>> key_list.sort(reverse = False)

Set类型


类型定义



  • 通过set定义普通集合
  • 通过frozenset定义不可变集合


简单示例


## 初始化
set_list = [2,39,9,3,4,5,28,34]
>>> s1 = set(set_list)
{2, 3, 4, 5, 34, 39, 9, 28}

>>> s2 = frozenset(set_list)
frozenset({2, 3, 4, 5, 34, 39, 9, 28})

## 判断包含关系
>>> print 9 in s1

## 判断子集关系
>>> print s1 >= s2

## 差运算
>>> print s1 - s2

## 交运算
>>> print s1 & s2

## 执行并运算并赋值给s1
>>> print s1 |= s2

## 对称差运算
>>> print s1 ^ s2 ## 获取s1不在s2的元素以及s2不在s1的元素

## 集合遍历
>>> for ele in s1:
... print(ele)

Dictionary类型


类型定义


  • 即字典类型,代表一个键值存储库,类似于映射表


简单示例


## 字典定义
>>> dc = {"name":"xiaokun","age":4,"title":"english name"}

## 读取元素
>>> print dc['name']

## 直接通过下标增加字典字段
>>> dc['new_name'] = 'new_value'

## 合并字典
>>> dc1 = {"name2":"xiaokun","age2":4,"title2":"english name"}
>>> dc.update(dc1)
个人公众号:

python核心基础纵览(上)_字符串