zoukankan      html  css  js  c++  java
  • 2018-06-11——pthyon类型整理

    二、类型

    我们人类可以很容易的分清数字与字符的区别,但是计算机并不能,计算机需要明确的告诉它,1是数字,“汉”是文字,否则它是分不清1和‘汉’的区别的。因此,在每个编程语言里都会有一个叫数据类型的东东,其实就是对常用的各种数据类型进行了明确的划分,你想让计算机进行数值运算,你就传数字给它,你想让他处理文字,就传字符串类型给他。

    type(name)//查看name的类型

    int(x)//将x转换为int形

    int(x,base=y)//转换为y进制

    int.bit_length()     //查看int的二进制长度

    str(x)//将x转换为str形x@zuhYJRX

    list[str]//将str转换为list,内部使用的是for

    列表转换字符串需要自己手动写for循环,但是如果列表里只有字符,可以直接使用str = “”.join(list) 完成转换

    *整数(int)

    在Python3里不再有long类型了,全都是int

    在32位机器上,整数的位数为32位,取值范围为-2**31~2**31-1,即-2147483648~2147483647

    在64位系统上,整数的位数为64位,取值范围为-2**63~2**63-1,即-9223372036854775808~9223372036854775807

    定义变量时,如果value是数字且不加引号,就是整数形

    *字符串(str)

    可索引

    在python中所有加了引号的都是字符串

    字符串在创建后无法修改(运算),如果修改(运算)在内存中其实是新建了一个字符串

    可以使用加和乘运算,加就是拼接,乘就是复制多少次在拼接在一起。

    name + name

    name * int //可以乘数字也可以乘变量

     

    str.capitalize()   //首字母大写

    str.casefold()   // 变小写,对应关系多

    str.center(x,“y”)   //设置宽度居中内容。一共x的总长度,str在中间,其 他默认是空格,使用y填充空白位置。。y只能是一个字符

    str.count('x')     //x在str里出现了多少次   start|end 从第几个位置开始往后|往前找,也就是寻找范围

    -str.decode //欠

    str.expandtabs(x) //断句!x为int,以x为单位,将str分组,如果存在tab则填空格补齐x个

     -str.encode //欠

    str.find('x')   //x在str中的第一次出现的位置,返回位数,未找到则返回-1,也可以选择查找范围同count,范围是>   <=,前开后闭

    str.format(x='y')   //将str中的x(占位符)格式化为y(指定的值,可以是字符和数字),x、y可以是多个。如果x是数字(从0开始),则format('y1',y2....)按顺序替换,

    str.format_map({"x":'y', ……})  //字典的方式,将str中的x替换为y 

    str.index('x')  //同find,但是未找到则报错

    str.isprintable() //查看str打印时是否都是真实的值而没有不可现 实的字符(如/t、/n),返回bool

    str.isspace() //查看str是否全部是空格(为空不算,要空格占位)

    str.istitle() //查看str中所有单词的首字母是否大写

    str.isalnum() //检查str中是否只有字母和数字,返回bool值

    ##原来是将str变成这个类型的方法,前面带上“is”,则是检查str是否是这个类型,返回bool

    str.isalpha()  //查看str是否全部是字母或汉字,返回bool

    str.isdigit()   //查看str是否全是数字,包含特殊字符的数字如②,返回bool

    str.isnumeric() //查看str是否全是数字,包含中文(字符)的数字如二,返回bool

    str.isdecimal()   //查看str是否全是数字,返回bool

    str.isidentifier()  //查看str是否符合标识符规则,返回bool

    str.islower() //判断str是否全是小写,返回bool

    str.join(x) //str插入到x的每个字符之间,str可以提前赋值,也可以直接打如“_*_”.join(test)

    str.l(r)just(x,“y”)  //将str放在x长度的字符串左(右)边,已y填充空格

    str.lower() // 将str转换成小写,对应关系少

    str0.maketrans("x","y") //给x和y做一个对应关系,这个关系叫str0

    str.(r)partition(‘x’) //匹配到str中的x(默认是从左边开始,加上r就是从右边开始)一次,在x的左右分割一次 ,也就是三份

    str.replace('x','y',num)//将str中的x替换成y,num是替换次数,默认-1

    str.(r)split('x',y)//匹配str中的x,匹配 y次进行分割,匹配到的x会被消除,默认y=-1也就是从右开始第一个,默认从左开始

    str.splitlines(‘true’) //只分割str里的换行,默认false,true是保留换行

    str.strip(lstrip strip)(‘x’)//去除str的(左右)x【x可以是字符串,会按方向去匹配,可能匹配到整个字符串,也可以是多个的任意个字符】,默认是空白,包括换行、tab 

    ##eg:test=xalex ;v = test.rstrip('96lexexdsxa') = 空白。都会匹配到

    ##经测试很乱这个类型,他是循环多次匹配,先最长,在最短,也就是如果你要过滤cat这个单词,可能c、a、t字母都会被过滤,而且还要考虑方向的顺序,不好控制

    #eg:test=1+2;v1,v2 = test.split('+')。。。此时v1=1,v2=2

    str.starts(ends)with('x') //判断str是否以x开头(结尾) 返回bool值

    str.swapcase()// 将str的大小写互换 

     

    str.title() //将str变为标题(首字母全部变为大写)你

    str.translate(str0)//使用str0的关系,替换str的值

    str.upper//将str转换成大写,对应关系少

    ***************************************

    str[x]//x是数字,表示获取str里的第x个字符,从0开始

    str[x:y]//获取str中x<=,<y位置的字符,当y为-1时,表示从右开始第一个,也就是只去掉最后一个字符,因为开区间。当x为-1时,会去掉所有的字符????

     

    *布尔(bool)

    也就是ture和false,主要用于判断

    *列表

    可索引、循环,可存储不同的数据类型,如数字、字符、布尔、列表等

     

    list = [‘x’,’y’]

    list = list([‘x’,’y’])

    列表中可以嵌套列表,可以通过索引、切片取值。可以多次索引取嵌套值

    增:

             li = [1,'a','b',2,3,'a']

    # li.insert(0,55) #按照索引去增加

    # print(li)

    #

    # li.append('aaa') #增加到最后

    # li.append([1,2,3]) #增加到最后

    # print(li)

    #

    # li.extend(['q,a,w']) #迭代的去增

    # li.extend(['q,a,w','aaa'])

    # li.extend('a')

    # li.extend('abc')

    # li.extend('a,b,c')

    # print(li)

    删:

             # l1 = li.pop(1) #按照位置去删除,有返回值

    # print(l1)

    # del li[1:3] #按照索引位置去删除,也可切片删除没有返回值。

    # print(li)

    # li.remove('a') #按照指定元素去删除,默认从左开始,删除一次

    # print(li)

    # li.clear() #清空列表

    改;

             # 改

    # li = [1,'a','b',2,3,'a']

    # li[1] = 'dfasdfas'

    # print(li)

    # li[1:3] = ['a','b']

    # print(li)

    查:切片去查,或者循环去查。

    其他操作

    test=list.copy() //将list浅拷贝到test

    count(数)(方法统计某个元素在列表中出现的次数)。

    a = ["q","w","q","r","t","y"]

    print(a.count("q"))

    index(方法用于从列表中找出某个值第一个匹配项的索引位置)/默认从左往右寻找一次,可以设定起始值

    a = ["q","w","r","t","y"]

    print(a.index("r"))

    list.sort(key,reverse)//list默认从小到大排序(reverse=false)

    reverse (方法将列表中的元素反向存放)。

    a = [2,1,3,4,5]

    a.sort()# 他没有返回值,所以只能打印a

    print(a)

    a.reverse()#他也没有返回值,所以只能打印a

    print(a)

    *元祖

    可索引、循环、切片

    元组被称为只读列表,即数据可以被查询,但不能被修改,所以,字符串的切片操作同样适用于元组。可以和字符串、列表直接互相转换

    元祖中的一级元素不可被修改,不能增加或删除。二级及以下可以被修改、增加和删除

    #一般元祖在最后一个元素加个逗号,与方法区分开。元祖长度和元素数量不会变化

    tuple = (1,2,3)

    tuple = tuple((1,2,3))

    tuple.count(x)//查找tuple中x元素的数量

    tuple.index(x)// 查找tuple中x的索引位置。默认从左往右寻找一次,可以设定起始值

    *字典

    无序的,不可切片,可索引、循环

    Py中唯一的映射类型存储数据,即key-value形式

    dict = {"k1":"v1","k2","v2"}  //k1、k2两个值,分别是v1和v2。

    dict = dict({‘x’:’y’,’z’:5})

    k不可以是列表、字典

    v可以是任意类型

    字典的增

    # dic['li'] = ["a","b","c"]

    # print(dic)

    # setdefault 在字典中添加键值对,如果只有键那对应的值是none,但是如果原字典中存在设置的键值对,则他不会更改或者覆盖。

    # dic.setdefault('k','v')

    # print(dic)  # {'age': 18, 'name': 'jin', 'sex': 'male', 'k': 'v'}

    # dic.setdefault('k','v1')  # {'age': 18, 'name': 'jin', 'sex': 'male', 'k': 'v'}

    # print(dic)

    字典的删(对于pop如果前面是两个变量,则会返回k和v两个值)

    # dic_pop = dic.pop("a",'无key默认返回值') # pop根据key删除键值对,并返回对应的值,如果没有key则返回默认返回值

    # print(dic_pop)

    # del dic["name"]  # 没有返回值。

    # print(dic)

    # dic_pop1 = dic.popitem()  # 随机删除字典中的某个键值对,将删除的键值对以元祖的形式返回

    # print(dic_pop1)  # ('name','jin')

    # dic_clear = dic.clear()  # 清空字典

    # print(dic,dic_clear)  # {} None

    改:

    # dic = {"name":"jin","age":18,"sex":"male"}

    # dic2 = {"name":"alex","weight":75}

    # dic2.update(dic)  # 将dic所有的键值对覆盖添加(相同的覆盖,没有的添加)到dic2中

    # print(dic2)

    查:

    # value1 = dic["name"]  # 索引的方式查找,没有会报错

    # print(value1)

    #

    # value2 = dic.get("djffdsafg","默认返回值")  # 没有可以返回设定的返回值

    # print(value2)

    #dict.get("key",vlaue) //根据key获取dict中的对应value,如果把不匹配则返回value,默认返回none

    其他操作:

    # item = dic.items()

    # print(item,type(item))  # dict_items([('name', 'jin'), ('sex', 'male'), ('age', 18)]) <class 'dict_items'>

    # 这个类型就是dict_items类型,可迭代的

    # keys = dic.keys()

    # print(keys,type(keys))  # dict_keys(['sex', 'age', 'name']) <class 'dict_keys'>

    # values = dic.values()

    # print(values,type(values))  # dict_values(['male', 18, 'jin']) <class 'dict_values'> 同上

    #dict.fromkeys(["key1",............],value)//根据key序列创建dict并赋予统一的value

    字典的循环

    # dic = {"name":"jin","age":18,"sex":"male"}

    # for key in dic://只输出key

    #     print(key)

    #for item in dic.values()://只输出value
    #   print(item)

    # for item in dic.items()://以列表形式输出所有

    #     print(item)

    # for key,value in dic.items()://以字符形式输出所有

    #     print(key,value)

    *集合

    集合是无序的,不重复的数据集合,它里面的元素是可哈希的(不可变类型),但是集合本身是不可哈希(所以集合做不了字典的键)的。以下是集合最重要的两点:

    去重,把一个列表变成集合,就自动去重了。

    关系测试,测试两组数据之前的交集、差集、并集等关系。

    创建集合:set1 = set({1,2,'barry'})或set2 = {1,2,'barry'}

    s=frozenset()//定义不可变得集合

    set.isdisjoint(x,x1。。。。。)//判断set和x是否有交集,返回bool。x可以是多个

    set.issubset(x,x1.....)//判断set是否是x的子集?

    set.issuperset(x,x1.....)//判断x是否是set的子集

    set.update(x)//将set的值更新为x的值,x为可迭代的值4

             集合的增:set1 = {'alex','wusir','ritian','egon','barry'}

    set1.add('景女神')

    print(set1)

    #update:迭代着增加

    set1.update('A')

    print(set1)

    set1.update('老师')

    print(set1)

    set1.update([1,2,3])

    print(set1)

    集合的删:set1 = {'alex','wusir','ritian','egon','barry'}

    set1.remove('alex')  # 删除一个元素,元素不存在则报错

    set.discard()//删除x元素,x不存在时不报错

    print(set1)

    set1.pop()  # 随机删除一个元素

    print(set1)

    set1.clear()  # 清空集合

    print(set1)

    del set1  # 删除集合

    print(set1)

    集合的其他操作:

    (set=set-x==)set.difference_update(x)//set-x差集并更新set...其他几个计算也有update

    交集。(&  或者 intersection)

    set1 = {1,2,3,4,5}

    set2 = {4,5,6,7,8}

    print(set1 & set2)  # {4, 5}

    print(set1.intersection(set2))  # {4, 5}

    并集。(| 或者 union)

    set1 = {1,2,3,4,5}

    set2 = {4,5,6,7,8}

    print(set1 | set2)  # {1, 2, 3, 4, 5, 6, 7}
    print(set2.union(set1))  # {1, 2, 3, 4, 5, 6, 7}

    差集。(- 或者 difference)

    set1 = {1,2,3,4,5}

    set2 = {4,5,6,7,8}

    print(set1 - set2)  # {1, 2, 3}

    print(set1.difference(set2))  # {1, 2, 3}

    交叉补集。 (^ 或者 symmetric_difference)

    set1 = {1,2,3,4,5}

    set2 = {4,5,6,7,8}

    print(set1 ^ set2)  # {1, 2, 3, 6, 7, 8}

    print(set1.symmetric_difference(set2))  # {1, 2, 3, 6, 7, 8}

                       子集与超集:set1 = {1,2,3}

    set2 = {1,2,3,4,5,6}

    print(set1 < set2)

    print(set1.issubset(set2))  # 这两个相同,都是说明set1是set2子集。

    print(set2 > set1)

    print(set2.issuperset(set1)) # 这两个相同,都是说明set2是set1超集。

    frozenset不可变集合,让集合变成不可变类型。

    s = frozenset('barry')

    print(s,type(s))  # frozenset({'a', 'y', 'b', 'r'}) <class 'frozenset'>

    *深浅copy

    赋值运算中,其实变量指向的都是相应的内存,也就是说会出现多个变量名指向一个地址的情况。

    对于浅copy来说,第一层创建的是新的内存地址,而从第二层开始,指向的都是同一个内存地址,所以,对于第二层以及更深的层数来说,保持一致性。

    l1 = [1,2,3,['barry','alex']]

    l2 = l1.copy()

    print(l1,id(l1))  # [1, 2, 3, ['barry', 'alex']] 2380296895816

    print(l2,id(l2))  # [1, 2, 3, ['barry', 'alex']] 2380296895048

    l1[1] = 222 //修改1,l2不变

    print(l1,id(l1))  # [1, 222, 3, ['barry', 'alex']] 2593038941128

    print(l2,id(l2))  # [1, 2, 3, ['barry', 'alex']] 2593038941896

    l1[3][0] = 'wusir'//修改3.0,l1和l2都改变

    print(l1,id(l1[3]))  # [1, 2, 3, ['wusir', 'alex']] 1732315659016

    print(l2,id(l2[3]))  # [1, 2, 3, ['wusir', 'alex']] 1732315659016

    对于深copy来说,两个是完全独立的,改变任意一个的任何元素(无论多少层),另一个绝对不改变。

    import copy

    l1 = [1,2,3,['barry','alex']]

    l2 = copy.deepcopy(l1)

    print(l1,id(l1))  # [1, 2, 3, ['barry', 'alex']] 2915377167816

    print(l2,id(l2))  # [1, 2, 3, ['barry', 'alex']] 2915377167048

    l1[1] = 222

    print(l1,id(l1))  # [1, 222, 3, ['barry', 'alex']] 2915377167816

    print(l2,id(l2))  # [1, 2, 3, ['barry', 'alex']] 2915377167048

    l1[3][0] = 'wusir'

    print(l1,id(l1[3]))  # [1, 222, 3, ['wusir', 'alex']] 2915377167240

    print(l2,id(l2[3]))  # [1, 2, 3

  • 相关阅读:
    bzoj1878: [SDOI2009]HH的项链
    bzoj1053: [HAOI2007]反素数ant
    bzoj2456: mode
    bzoj2330: [SCOI2011]糖果
    bzoj1050: [HAOI2006]旅行comf
    bzoj1047: [HAOI2007]理想的正方形
    bzoj1968: [Ahoi2005]COMMON 约数研究
    bzoj1046: [HAOI2007]上升序列
    bzoj2440: [中山市选2011]完全平方数
    bzoj1202: [HNOI2005]狡猾的商人
  • 原文地址:https://www.cnblogs.com/gulanmoen/p/9167263.html
Copyright © 2011-2022 走看看