python 数组 元组 列表_python_Day_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 inAA:
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 inname:
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 indictionary_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 数组 元组 列表_python_Day_02[数组、列表、元组之篇]相关推荐
- Python基础学习!容器:列表,元组,字典与集合!(2)
本文是元组 字典与集合的学习笔记! 真滴好多! 在许多地方都可以用元组代替列表,但是元组的方法函数与列表相比要少. 像,append(),insert()这些函数,元组都没有.因为,创建元组就无法修改 ...
- python基础语法合集-Python基础语法(四)—列表、元组、字典、集合、字符串
列表 基本概念列表是有序的元素集合,所有元素放在一对中括号中,用逗号隔开,没有长度限制: 列表索引值以0为开始值,-1为从未尾的开始位置. 列表可以使用+操作符进行拼接,使用*表示重复. 当列表元素增 ...
- python的集合类型——字符串、列表、元组、字典
集合类型 1.字符串 下标索引 所谓下标,就是编号,就好比超市中的存储柜的编号,通过这个编号就能找到相应的存储空间 字符串实际上就是字符数组,所以也支持下标索引 如果有字符串:name = 'abcd ...
- python元组和列表教程_Python列表和元组
Python是没有数组的概念,但是和数组比较相近的概念是列表和元素. 下面两个例子展示列表和元组. # coding=utf-8 # 元组 students = ('小明', '小黄', '小李', ...
- python读取字典元素笔记_Python中列表、字典、元组数据结构的简单学习笔记
列表 列表是Python中最具灵活性的有序集合对象类型.与字符串不同的是,列表可以包含任何类型的对象:数字.字符串甚至其他列表.列表是可变对象,它支持原地修改的操作. Python的列表是: 任意对象 ...
- python中存储坐标_最好使用元组或numpy数组来存储坐标
在内存消耗方面,numpy数组比Python元组更紧凑. numpy数组使用一个连续的内存块.numpy数组的所有元素必须是声明的类型(例如32位或64位float).Python tuple不一定使 ...
- python基础系列教程——数据结构(列表、元组、字典、集合、链表)
全栈工程师开发手册 (作者:栾鹏) python数据挖掘系列教程 基本顺序存储结构--列表与元组 Python中的基本顺序存储结构是列表与元组,在操作的复杂度上和数组完全相同,其中列表是可变数据类型, ...
- python中列表是什么样的数据结构_Python中列表、字典、元组、集合数据结构整理...
Python常见数据结构整理 Python中常见的数据结构可以统称为容器(container).序列(如列表和元组).映射(如字典)以及集合(set)是三类主要的容器. 一.序列(列表.元组和字符串) ...
- 概念一: python 中列表 ,数组, 集合,字典;
1. python 基本数据类型 首先python3 中 自带的 有 六个标准的数据类型: Number(数字) String(字符串) Tuple(元组) List(列表) Set(集合) Dict ...
最新文章
- linux挂载硬盘_一篇文章带你了解 linux 如何进行挂载
- php复制mysql文件路径_与php 有关的问题 如何将上传的文件路径 保存到数据库中...
- node 跨域请求设置
- 【C语言】控制台窗口图形界面编程(五):文本移动
- windows nssm将应用程序做成服务的实例
- Web程序员的Mysql进阶序三之sql多表数据删除、子查询、联合查询
- 前端学习(604):编程语言
- 33--二维数组中的查找
- 专访阿里云专有云马劲,一个理性的理想主义者
- 避开Google Voice Search利用Google Speech API实现Android语音识别
- LeetCode(389)——找不同(JavaScript)
- WPF TextBox提示文字设定
- 软件产品售后服务的内容方案
- matlab 自写 自适应中值滤波 matlab自适应中值滤波算法
- 110kV终端变电站电气部分设计
- 万能的林萧说:我来告诉你,一个草根程序员如何进入BAT。
- python list切片_python list切片
- 启动计算机配置windows7,如何设置开机启动项,教您电脑如何设置win7开机启动项...
- SVN: E155036:This client is too old to work with working copy…解决方法
- 春节烟花特效(基于野火stm32指南者开发板屏幕)
热门文章
- 【Flink】 Flink与Kafka版本对应关系
- 【Elasticsearch】ElasticSearch里面的偏好查询
- 【Kafka】Kafka Producer整体架构概述及源码分析
- 【Elasticsearch】搜索引擎从0到1 有赞 视频笔记
- 【hortonworks/registries】registries curator LeaderLatch: getChildren() failed. rc = -6 Xid 110
- 【java】ASM代理方式 Byte-Buddy代理方式 Javassist代理方式
- 【Kafka】kafka消费组查看lag
- 【hortonworks/registry】AVRO 规范-Schema的定义和声明
- Spring : Spring @Transactional-嵌套事物回滚
- dubbo-admin的编译安装