day2 -- 字符串常用方法、列表、字典
1.字符串常用方法
name = "Convict abc"
count(): print(name.count("c")) # 2
find(): print(name.find("a")) # 8
index(): print(name.index("a")) # 8 如果找不到,会报错
根据下标区间取值: print(name[0: 4]) # Conv
format():
new_name = "my new name is {name}"
print(new_name.format(name="GG"))
# my new name is GG
isdigit():判断是否为数字
print("11".isdigit()) # True
print("abc".isdigit()) #False
join():将要连接的元素序列、字符串、元组、字典 连接形成新的字符串
print("==".join(["1", "a", "M"])) # 1==a==M
strip():去除首尾空格和换行
print(" abc \n".strip()) # abc
split():按照方法参数中的字符分割,返回分割后的列表
print("1+2+a+c".split("+")) # ['1', '2', 'a', 'c']
2.列表:类似于C或者Java的数组(有序,可以通过下标取值)
values = ["aaa", "bbb", "ccc"]
然而列表也可以存放列表,例如:
values = ["aaa", "bbb", "ccc", "ddd", "eee", "ddd", ["ddd", "eee"]]
列表的常用方法
# 按下标取
# 正序
print(values[0])
print(values[1])
# 负号表示逆着数,一般常用-1来取最后一个值
print(values[-1]) # 按下标区间取 [起始,终点),所以是不包括最后一个的
# eg1:取下标 1, 2, 3 对应的值
print(values[1:4])
# eg2:-3对应bbb,-1对应ddd
print(values[-3:-1])
# eg3:如果取某一下标直到结尾,冒号之后不写下标即可
print(values[-2:])
# eg4:如果从起始位置起到某一指定位置,冒号前不写下标即可
print(values[0:2]) # 按下标,同时加步长
print(values[0:-1:2])
print(values[::2])
print(values[:]) # 增加
values.append("OFF")
print(values)
values.insert(1, "INSERT")
print(values) # 修改
values[0] = "AAA"
print(values) # 删除
values.remove("OFF") # 直接找这个值并且删除,找不到会报错
print(values) del values[2]
print(values) values.pop(-2) # 取出,可以拿到对应下标的值,如果方法不传参,默认最后一个
print(values) # 找下标位置,根据参数找,找不到报错
print(values.index("ddd")) # 统计
print(values.count("ddd")) # 清空
values.clear()
print(values) # 扩展
values2 = ["!!!", "@@@"]
values.extend(values2)
print(values) # 排序, 特殊字符 > 数字 > 英文大写 > 英文小写, 即按照ASCII排序规则
values.sort()
print(values) # 反转
values.reverse()
print(values) # copy 只复制首层列表,多重列表的内层列表不复制,内层列表copy的都是同一个内存地址指针
values3 = values.copy()
print(values3) names = ["a", "b", ["MM", "NN"], "d"]
names2 = names.copy()
print(names)
print(names2) names2[1] = "B"
print(names)
print(names2) names[2][0] = "123"
print(names)
print(names2) # (深copy)直接copy一个副本,数据大时最好不用这个,否则资源消耗大
import copy
names = ["a", "b", ["MM", "NN"], "d"]
names2 = copy.deepcopy(names)
print(names)
print(names2) names[2][0] = "123"
print(names)
print(names2) # 元组tuple(只读列表),只能读的列表,没有增删改操作
names = ("A", "B")
print(names) # 查找字符在列表中的下标
name = "abc"
print(name.index("a")) # 找不到直接报错
print(name.find("d")) # 找不到返回-1
3.字典: key-value 形式的数据类型,键值对类型,类似于json格式,(无序,通过key取值)例如:
person1 = {
"name": "AAA",
"age": 12,
"addr": "China"
}
然而字典存放的也可以是字典,例如:
people = {
"p1": person1,
"tel": 888666000
}
对字典取值:
①知道key,直接 字典[“key”]取值,如:
print(person1["age"]) # 12
# 但如果这key是不存在的,则会报错,如 print(person1["bbb"]) 会直接报错
②.get()方法
print(person1.get("age")) # 12
print(person1.get("aaa")) # None
# .get()可以传字典中不存在的key,返回 None,取值时候建议用这个方法
对字典删除:
①知道key,直接 字典[“key”]取值,如:
del person1["aaa"] # 删除key为aaa的整个值,如果key不存在,则会报错
②.pop()方法,取出字典中指定的key以及key所对应的值,所以这个方法是有返回值的,且原字典会移除对应的key及value,如果key不存在则报错
person1.pop("age") # 12
③.popitem()方法,随机取出key以及key所对应的值,有返回值,原字典会移除对应的key及value
person1.popitem() # 随机的
对字典增加:类似json,直接往字典添加key跟value即可
person1["salary"] = 4500
对字典修改:
person1["name"] = "new Name" # 如果key是原字典不存在的,就变成了增加
day2 -- 字符串常用方法、列表、字典的更多相关文章
- Python之路 day2 字符串/元组/列表/字典互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- python_way ,day2 字符串,列表,字典,时间模块
python_way ,day2 字符串,列表,字典,自学时间模块 1.input: 2.0 3.0 区别 2.0中 如果要要用户交互输入字符串: name=raw_input() 如果 name=i ...
- python字符串/元组/列表/字典互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- 转:python字符串/元组/列表/字典互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ...
- python 小白(无编程基础,无计算机基础)的开发之路,辅助知识6 python字符串/元组/列表/字典互转
神奇的相互转换,小白同学可以看看,很有帮助 #1.字典dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ...
- Python基础二_操作字符串常用方法、字典、文件读取
一.字符串常用方法: name.captitalize() #字符串首字母大写 name.center(50,'*') ...
- 【转】python字符串/元组/列表/字典互转
#-*-coding:utf-8-*- #1.字典 dict = {'name': 'Zara', 'age': 7, 'class': 'First'} #字典转为字符串,返回:<type ' ...
- day2 字符串常用方法总结
字符串在Python中是常用的功能,我们知道,字符串在Python中存储的形式是以字符数组的形式存在,比如"alex"在内存中的存储形式是:["a"," ...
- python基础之数据类型/字符串/元组/列表/字典
Python 数据类型 数字类型: int整型,long 长整型(在python3.0里不区分整型和长整型).float浮点型:complex复数(python中存在小数字池:-5--257):布尔值 ...
随机推荐
- Oracle打怪升级之路二【视图、序列、游标、索引、存储过程、触发器】
前言 在之前 <Oracle打怪升级之路一>中我们主要介绍了Oracle的基础和Oracle常用查询及函数,这篇文章作为补充,主要介绍Oracle的对象,视图.序列.同义词.索引等,以及P ...
- 初识python 之 ImportError: No module named _ssl
场景 安装好python之后,导入ssl模块报错: ImportError: No module named _ssl 解决方法 查看openssl.openssl-devel是否安装 rpm -qa ...
- 不用下载Axure RP Extension for Chrome插件查看原型文件的方法
Axure RP Extension for Chrome是一款谷歌插件,主要可以用来查看原型文件.以前安装插件的时候总是找半天资源,很麻烦,最近发现了一种新方法可以不用下载插件资源.其实在原型文件中 ...
- 简单的Dos 命令
1.1.如何操作DOS命令 开始---运行---输入cmd--回车 或者 Win + R ---运行---输入cmd--回车 1.2.基本命令 1. 命令:color f0 帮助:color ? 作用 ...
- 求n以内最大的k个素数以及它们的和
本题要求计算并输出不超过n的最大的k个素数以及它们的和. 输入格式: 输入在一行中给出n(10≤n≤10000)和k(1≤k≤10)的值. 输出格式: 在一行中按下列格式输出: 素数1+素数2+-+素 ...
- 拉普拉斯平滑(Laplacian smoothing)
概念 零概率问题:在计算事件的概率时,如果某个事件在观察样本库(训练集)中没有出现过,会导致该事件的概率结果是 $0$ .这是不合理的,不能因为一个事件没有观察到,就被认为该事件一定不可能发生(即该 ...
- dubbo接口方法重载且入参未显式指定序列化id导致ClassCastException分析
问题描述&模拟 线上登录接口,通过监控查看,有类型转换异常,具体报错如下图 此报错信息是dubbo consumer端显示,且登录大部分是正常,有少量部分会报类型转换异常,同事通过更换方法名+ ...
- dubbo 实现简易分布式服务
dubbo 实现简易分布式服务 服务器需要搭建zookeeper环境 zookeeper端口2181 还需要有java环境 1.需求 某个电商系统,订单服务需要调用用户服务获取某个用户的所有地址: 我 ...
- Java将引入新的对象类型来解决内存利用问题
2022年Java将有什么新的特性和改进,我相信很多Java开发者都想知道.结合Java语言架构师布莱恩·格茨(Brian Goetz)最近的一些分享,胖哥给大家爆个料.老规矩,点赞走起. Valha ...
- Centos上通过yum命令删除有关MySQL
1.停止mysql 服务service mysql stop 2.刚开始使用的yum安装的,使用以下语句进行卸载 yum remove mysql* 3.然后删除mysql旧版本已经存在的文件或者数据 ...