python_S13_02[数组列表元组]

Posted lcj122

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python_S13_02[数组列表元组]相关的知识,希望对你有一定的参考价值。

一、对python中.pyc的理解

1).pyc文件可以理解为是python编译好的字节码文件,即只有python解释器才能读懂,类似于java中class文件

2)python运转过程:

当python程序运转时,编译的结果是保存在位于内存中的PyCodeObject中,当Python程序运行结束时,Python解释器则将PyCodeObject写回到pyc文件中

当程序第二次运行时,首先程序会在硬盘中寻找pyc文件,如找到,则直接载入,否则就重复上面的过程。

总结:PyCodeObject和pyc文件关系,pyc文件其实是PyCodeObject的一种持久化方式

二、数据类型

1、数字

int(整型)

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

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

long(长整形)

跟C语言不同的是,Python的长整数没有指定位宽,即:python没有限制长整数数值大小,但实际上由于机器内存的有限,我们使用的长整数数值不可能是无限大

注意:自从python2.2之后,如果整数发生溢出,python会自动将整数数据转换为长整数,所以如今长整数数据后面不加字母L也不会导致严重后果了

float(浮点型)

  浮点数主要是用来处理实数,即带有小数的数字,类似C语言中的double类型,占8个字节(64位),其中52表示底,11位表示指数,剩下的一位表示一位表示符号。

布尔值

  真或假

  1或0

字符串

“Hello World”

万恶的字符串拼接:

  Python中的字符串在C语言中体现是为了一个字符数组,每次创建字符串时候需要在内存中开辟一块连续的空间,并且一旦开启需要修改字符串的话,就需要再次开辟空间,万恶的“+”号每次出现一次就会在内存中重新开辟一块空间。

一般字符串输出格式:

2、列表

  写法:name_list = [\'dayi\',\'daer\',\'dasan\']        #列表必须是用[]

  或者

  name_list = list([\'dayi\',\'daer\',\'dasan\'])

AA = [32,45,6,7,8,975,3,5,65,6,62121,2,3,3,44,55,]
if 3 in AA:
    num_of_ele = AA.count(3)     #查找在列表中为3的元素
    position_of_ele = AA.index(3)   #利用索引找到为3元素的位置,并将为三的元素转换给变量position_of_ele
    AA[position_of_ele] = \'xiaoxiao\'     #对变量重新赋值
    print("[%s] 3 is/are in AA,postion:[%s]"%( num_of_ele,position_of_ele))
    print(AA)
for i in range(AA.count(3)):   #for循环  查找列表中出现为3的元素,,
    ele_index = AA.index(3)  #并且找到为3元素的索引
    AA[ele_index] = \'99999\'  #再为3的元素进行重新赋值
    print(AA)
#追加   extend:扩展新的列表  把两个列表合并
aa = [\'xiaoluo\',\'lcj\',\'ljk\',\'62121\']
AA.extend(aa)  #将列表aa中的元素追加至列表AA列表中,如有元素有重复不影响
print(AA)
print(aa)
#reverse :翻转列表中各元素,不改变列表中的各个元素
AA.reverse()
print(AA)
#给列表排序  sort  注意:python3.0不支持列表中的字符串和数据混合排序,python2.0则支持
#先数字,在字符串,特殊符号、、、
# AA.sort()
# print(AA)
print(aa)
#pop方法:只默认删除列表中最后一位元素,也可指定列表中的元素
aa.pop()
print(aa)
aa.pop(\'lcj\')   #指定删除aa列表中的lcj元素
print(aa)

  列表的基本操作:

  1)索引:python中的索引又称下标(下标就是列表中各元素的排序序号,从0开始)

  2)切片:即指定那些元素切换出来,不影响之前列表中各元素,即可层层切换出需要的元素[切1][切2][切2.2]

  3)修改:对列表已知的元素进行修改,此时,用到变量,即是给需要修改的值进行重新赋值

 

 3)插入(insert):,一次只能插入一个值,注意插入的符号为()

  4)追加(append):一般列表最后追加一个元素

  

  5)删除(remove):

  6)字符串步长

r = \'1234567890\'
print(r[:])  #1234567890
print(r[1:])  #234567890左闭右开,从左至右以第一个字符开始直到最后字符串结束
print(r[2:]) #34567890
print(r[3:]) #4567890 从第三个字符开始直到最后元素结束
print(r[1:2])  #2
print(r[1:5])  #2345
print(r[::2])  #13579 按照步长为两个字符进行输出
# print(r[1:-1])
print(r[-1:1])  #无字符串输出
print(r[1:-1])  #23456789

   练习:

#1、找出列表中有多少个9,把他改成9999
#2、同时找出所有的34,并把他删除
name = [34,45,43,34,34,34,3,3,45,5,76,9,6,9,34,34,3,2,3,9,12]
if 9 in name:
    num_of_ele = name.count(9)    #统计列表中为9的元素对的个数,没找到一个自增加1
    position_of_ele = name.index(9)   #查找元素9的索引
    name[position_of_ele] = \'99999\'   #对列表中元素通过变量重新赋值
    print(\'[%s] 9 is/are name, postion:[%s]\'%(num_of_ele,position_of_ele))
    print(name)
for i in range(name.count(9)):   #通过for循环查找列表中9的元素
    ele_index = name.index(9)     #查询列表中9的索引
    name[ele_index] = \'9999\'
    print(name)
for i in range(name.count(34)):  #删除列表中34的元素
    #ele_index2 = name.index(34)
    name.remove(34)
    print(name)

   三、字典(dist)无序

  创建字典格式:dist = {"dd","ff","gg","hh",43}

  dist = ({"name":“mr.wu”,\'age\':32})

  字典中可嵌套数据:

  shop = {\'家电类\':[(\'电视\',2999),(\'冰箱\',3999),(\'洗衣机\',2999),(\'热水器\',5000)]}

   1)、提取字典中某一个元素:print(dict[dict的key])

  2)、修改字典中某一个元素:dict[key][\'value\'] = \'新的值\'

  3)、字典中插入某一个元素:dict[key][\'插入元素\'] = ‘值’

  4)、字典中删除某一元素:dict[key].pop(‘values’)

  5)、获取字典中的元素:get方法。例如:dict.get[‘values’]

  6)、更新字典update方法:

  将dict2中的元素更新至dict1中:dict1.update(dict2)

  7)、字典for循环

  方法一:for k,v in dict.items():     #效率低,当数据量大时,字典转换成列表耗时慢

        print(k,v)

  方法二:for key in dict.items():    #在列表中查找key值,并将key中的value值打印出

        print(key,dict.[key]) 

dictionary_lcj = {
    4210221990012215234:{
    \'user_name\':\'hhh\',
    \'age\':22,
    \'Address\': \'北京\'
    },
    4210221990012215233:{
    \'user_name\':\'jjj\',
    \'age\':22,
    \'Address\': \'上海\'
    },
    4210221990012215236:{
    \'user_name\':\'kkk\',
    \'age\':22,
    \'Address\': \'天津\'
    }
}
user2 = {

    4210221990012215236: {
        \'user_name\': \'kkk\',

        \'Address\': \'天津\'
}}

# print(dictionary_lcj)
# print(dictionary_lcj[4210221990012215236])   #在字典中提取某一字典数据
# dictionary_lcj[4210221990012215236][\'Address\'] = \'广州\'  #对字典中元素进行重新赋值,注意:字典格式为{},列表格式为[]
# print(dictionary_lcj)
# dictionary_lcj[4210221990012215236][\'qq\'] = 2132323   #在字典中插入新增加元素,先提取嵌套字典,在对新增加的元素进行赋值
# print(dictionary_lcj)
# dictionary_lcj[4210221990012215236].pop(\'Address\')  #删除字典中指定的元素,注意
# print(dictionary_lcj)
#获取字典中元素:get
# dictionary_lcj.get(4210221990012215236)
# v = dictionary_lcj[4210221990012215236]   #将嵌套的字典赋予一个变量,打印变量
# print(v)
#update更新字典,将user2中的元素更新至dictionary_lcj
# dictionary_lcj.update(user2)
# print(dictionary_lcj)
#items元素:把字典变成为一个元祖或者一个列表,当数据量较多时不建议把字典转化为列表,
# print(dictionary_lcj)
# print(dictionary_lcj.items())

#元素:values----》将所有字典中values值
#print(dictionary_lcj.values())
#元素:keys------》打印字典中国所有的key值,
#print(dictionary_lcj.keys())

#判断一个某一个k是否存在于字典中
print(421022199001221523623 in dictionary_lcj)
#元素:setdefault,表示在字典中如果key值存在则打印,否则key值不存在,系统默认返回一个None值,也可在指定返回的值
#print(dictionary_lcj.setdefault(421022199001221523623),\'哈哈\')  #表示当k值不存在,则返回‘哈哈’
#fromkeys:把列表中每一个值当做字典中的 一个k,并把这个值赋值给这个K,大王说这是一个抗,还没说是啥抗
# print(dict.fromkeys([1,2,3,4],\'lcj\'))   #通过默认的字典调用者个列表
# print(dictionary_lcj.fromkeys([1,2,3,4],\'lcj\'))
# #popitem:随机删除字典中元素,当数据量较大时明显,python中一般不建议使用随机方法
# print(dictionary_lcj.popitem())
# print(dictionary_lcj)

#字典for循环
for k ,v in dictionary_lcj.items(): #效率低,有一个字典转换为一个列表的过程
    print(k,v)
for key in dictionary_lcj:          #查找dictionary_lcj中key值,再讲key中的值打印出
    print(key,dictionary_lcj[key])

   8、枚举方法:

    方法:numerate,将数组a中的元素赋值为一个元祖,并把元祖的下标打印

 四、元组

  元组为不可变得列表:  tuple一旦初始化就不能修改

  ages  = (12,33,22,45,67) 或 ages = tuple((21,32,43,54,74)) 

  五、常用字符串方法补充

  1、判断字符串中是否存在空格  

name = "lc j "
print(" "in name) #判断字符串中是否存在空格。返回True则存在,False:不存在

 

  2、判断输入是否是数字:isdigit

age = input("your age:")
if age.isdigit():  #判断输入是否是数字
	age = int(age) 
	print(age)
else:
	print("请输入数字!!!")

 

  3、判断输入是否是阿拉伯数或者数字,不包含特殊字符

  元素:isalnum

#判断输入是否是阿拉伯数字或数字
name = \'laj123\'
print(name.isalnum()) #如打印为True则表示输如是数字或者阿拉伯数字,不含包含特殊字符

  4、判断以某某开始或结束

  开始:startwith

  结束:endwith

name = "lcj123"
print(name.startswith(\'l\'))  #判断是否是字符串开始
print(name.endswith(\'123\')) #判断是以某某结束,True:表示是,False:表示否

  4、规定字符串输出是否按照大小写输出

  upper或lower

name = "lcj123dsds"
print(name.upper())  #将字符串按照大写输出
print(name.lower()) #将字符串按照小写输出

  5、将字符串首字母按照大写进行输出

  capitalize

name = "lcj123"
print(name.capitalize()) #将字符串首字母按照大写输出

  6、去掉字符串中前后空格

  #strip()

username = input("user:")
if username.strip() == \'lcj\': #将输入的字符串前后空格去掉
	print("welcome")

  三、计算

  1、算数运算:

  2、比较运算符

  3、赋值运算

  4、逻辑运算

  5、成员运算

  6、位运算

  7、运算符优先级

  8、身份运算

 

以上是关于python_S13_02[数组列表元组]的主要内容,如果未能解决你的问题,请参考以下文章

零基础学习python_列表和元组(10-13课)

如何对 spark scala RDD 中的元组列表/数组执行转换?

在 Python 元组列表中查找重复项

Python_02

如何根据某些文本标准对元组列表进行分组/存储?

python 数组和列表的区别