python 入门第三天(高级进阶:str、set、dict、slice、推导式、高级变量类型的公共语法)

本文主要是介绍python 入门第三天(高级进阶:str、set、dict、slice、推导式、高级变量类型的公共语法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、字符串str

字符串就是一串字符,是编程语言中表示文本的数据类型

1. 字符串定义

Python中可以使用一对双引号或者一对单引号定义字符串

str1 = 'hello'
str2 = "hello"

2. 获取字符串中元素

和列表一样,字符串也是通过索引获取元素

str = "hello"
# 获取第三个元素
ele = str[2] # l

3. 遍历字符串

可以通过for循环遍历字符串

str = 'hello'
for ele in str:print(ele)

4. 字符串的常见操作

4.1. 判断

方法

说明

isalpha()

如果 string 至少有一个字符并且所有字符都是字母则返回 True

isdecimal()

如果 string 只包含数字则返回 True

startwith(str)

检查字符串是否是以 str 开头,是则返回 True

endswith(str)

检查字符串是否是以 str 结束,是则返回 True

4.2. 查找替换

方法

说明

find(str, start=0, end=len(string))

检测 str 是否包含在 string 中,如果 start 和 end 指定范围,则检查是否包含在指定范围内,如果是返回开始的索引值,否则返回 -1

rfind(str, start=0, end=len(string))

类似于 find(),不过是从右边开始查找

replace(old_str, new_str, num=string.count(old))

返回一个新字符串,把 string 中的 old_str 替换成 new_str,如果 num 指定,则替换不超过 num 次

4.3. 切割

方法

说明

split(str="", maxsplit)

返回列表,以 str 为分隔符拆分 string,如果 maxsplit 有指定值,则仅分隔 maxsplit + 1 个子字符串,str 默认包含\r, \t, \n空格

4.4. 去空白

方法

说明

strip()

返回新字符串,截掉 string 左右两边的空白字符(可以指定截掉的字符)

5. 练习-用户名和密码校验

# 需求
# ● 用户名和密码格式校验程序
# ● 要求从键盘输入用户名和密码,分别校验格式是否符合规则
#   ○ 如果符合,打印用户名合法,密码合法
#   ○ 如果不符合,打印出不符合的原因,并提示重新输入
# ● 用户名长度6-20,用户名必须以字母开头
# ● 密码长度至少6位,不能为纯数字,不能有空格# 1.从键盘输入用户名(需要while循环)
# # 2.长度6-20
# # 3.必须字母开头
# #
# # 4.输入密码(while循环)
# # 5.密码长度至少6位
# # 6.不能为纯数字
# # 7.不能有空格while True:username = input("请输入用户名:")if 6<=len(username)<=20:if username[0].isalpha():print("合法")breakelse:print("用户名必须以字母开头")continueelse:print("用户名长度必须在6-20之间")continuewhile True:password = input("请输入密码")if len(password)<6:print("密码长度至少6位")continueif password.isdecimal():print("密码不能为纯数字")continueif ' ' in password:print("密码不能有空格")continueprint("密码合法")break

  扩展:

  • isalpha()字符串中所有元素都是字母,则返回True
  • isdecimal()字符串中都是数字,则返回True

二、集合set

set被称为集合,是无序的,并且集合中的元素是唯一的

1. 集合的创建

s = {'张三','李四','王五'}

集合是无序的

s = {'张三','李四','王五'}
print(s)

结果:

{'王五', '张三', '李四'}

集合元素唯一

s = {'张三','李四','王五','张三'}
print(s)

结果:

{'李四', '张三', '王五'}

2. 遍历集合中元素

通过for循环遍历集合中的元素

s = {'张三','李四','王五'}
# 遍历集合
for ele in s:print(ele)

3. 集合中添加元素

集合可以通过add方法添加元素

s = {'张三','李四','王五'}
# # 添加赵六 add
s.add('赵六')

4. 集合删除元素

remove删除,如果有 直接删除,如果没有 程序报错

s = {'张三','李四','王五'}
# 删除张三 
s.remove('张三')

pop删除,随机删除集合中的元素并返回,如果集合中没有元素,则程序报错

s = {'张三','李四','王五'}
# pop 随机删除
print(s.pop())

discard删除,元素存在则直接删除,如果元素不存在,则不做任何操作

s = {'张三','李四','王五'}
# discard 删除元素 如果元素不存在,不做任何处理
s.discard('林青霞')

三、dict字典

1. 字典的定义

  • 字典用{}定义
  • 键值对之间使用,分隔
  • 之间使用:分隔
d = {'中国':'China','英国':'England','美国':'America'}

2. 字典的特点

字典中的相当于索引,必须是唯一的

d = {'中国':'China','英国':'England','美国':'America','美国':'USA'}
print(d)

运行:

{'中国': 'China', '英国': 'England', '美国': 'USA'}

3. 字典增删改查

3.1. 增加

字典增加元素

d = {'中国':'China','英国':'England','美国':'America'}
# 添加 法国
d['法国'] = 'France'

也可以通过setdefault方法添加

d.setdefault('法国','France')

3.2. 删除

字典删除元素

d = {'中国':'China','英国':'England','美国':'America'}
# 删除美国 如果键不在字典中,会报错
del d['法国']

也可以通过pop删除

# pop 删除元素 并且返回删除元素的值 如果删除不存在会报错
result = d.pop('法国')

清空字典

# 清空容器中的数据  还可以继续使用
d.clear()

3.3. 修改

修改字典中元素

d = {'中国':'China','英国':'England','美国':'America'}
# 修改美国
d['美国'] = 'USA'

3.4. 查询

查询元素

d = {'中国':'China','英国':'England','美国':'America'}
# 查找中国
value = d['中国']
print(value)

4. 字典遍历

4.1. 遍历所有的键值对

通过for循环遍历字典所有的键值对

d = {'中国':'China','英国':'England','美国':'America'}for ele in d:print(ele,d[ele])

结果:

中国 China
英国 England
美国 America

4.2. 遍历所有的键

d = {'中国':'China','英国':'England','美国':'America'}
for key in d.keys():print(key)

结果:

中国
英国
美国

4.3. 遍历所有的值

d = {'中国':'China','英国':'England','美国':'America'}for value in d.values():print(value)

结果:

China
England
America

4.4. 遍历所有的键值对

d = {'中国':'China','英国':'England','美国':'America'}
for key,value in d.items():print(key,value)

结果:

中国 China
英国 England
美国 America

5. 字典的应用场景

使用多个键值对,存储描述一个物体的相关信息---描述更复杂的数据信息

d = {'name':'张三','phone':'12332','age':40,'性别':'男'}

四、slice切片

1. 切片简介

取一个strlisttuple的部分元素是非常常见的操作

  • 切片 译自英文单词slice,指的是一部分
  • 切片 根据 步长step 从原序列中取出一部分元素组成新序列
  • 切片适用于 字符串、列表、元组

2. 切片的格式

字符串[开始索引:结束索引:步长]

包含开始索引, 不包含结束索引

2.1. 需求

string = '中华人民共和国欢迎您'
获取前三个文字

2.2. 代码

string = '中华人民共和国欢迎您'
# 获取前三个文字
newStr = string[0:3:1]

步长默认为1,可以省略,如下

newStr = string[0:3]

开始索引为0,可以省略,如下

newStr = string[:3]

如果到末尾结束,可以省略结束索引,例如取后三个字“欢迎您

newStr = string[7:]

3. 索引的正序和倒序

索引分为正序和倒序

  • 正序:从左向右,0开始
  • 倒序:从右向左,-1开始

3.1. 需求

ss = "中华人名共和国欢迎您"
把字符串中从第一个到倒数第二个(不包含)打印出来

3.2. 代码

ss = "中华人名共和国欢迎您"
# 把字符串中从第一个到倒数第二个(不包含)打印出来
# 开始位置:正序  结束位置:倒序
print(ss[:-2])

4. 步长为负数

步长也可以为负数,代表逆序切片

4.1. 需求

ss = "中华人名共和国欢迎您"
把从角标为2到7(包含)倒序打印出来

4.2. 代码

ss = "中华人民共和国欢迎您"
# 把从角标为2到7(包含)倒序打印出来
# 欢国和共名人
print(ss[7:1:-1])

五、推导式

推导式指的是轻量级循环创建数据的方式,对列表或可迭代对象中的每个元素应用某种操作,用生成的结果创建新的列表;或用满足特定条件的元素创建子序列。

推导式包括:

  • 列表推导式
  • 元组推导式
  • 集合推导式
  • 字典推导式

1. 列表推导式

列表推导式的格式:[计算公式 for循环 if判断]

通过列表推导式快速创建[1, 11)所有数字的列表

lst = [ele for ele in range(1, 11)]
# [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

通过列表推导式快速创建[1, 11)所有偶数的列表

lst = [ele for ele in range(1, 11) if ele % 2 == 0]
# [2, 4, 6, 8, 10]

通过列表推导式快速创建[1, 11)所有偶数的平方的列表

lst = [ele ** 2 for ele in range(1, 11) if ele % 2 == 0]
# [4, 16, 36, 64, 100]

2. 元组推导式

元组推导式的格式:(计算公式 for循环 if判断),其他与列表推导式一致

tp  =(ele for ele in range(1, 11))

3. 集合推导式

集合推导式的格式:{计算公式 for循环 if判断},其他与列表推导式一致

s = {ele for ele in range(1, 11)}

4. 字典推导式

d = {key:value for key, value in zip(range(1,10),range(21,30))}

zip(..., ...)range(1,10)range(21,30)里的每个元素一一组合成元组

(1, 21)
(2, 22)
(3, 23)
...
(8, 28)
(9, 29)

再把这些元组打包成一个可迭代对象。

5. 推导式练习

# 需求
# 请写出一段 Python 代码实现分组一个 list 里面的元素
# 比如 [1,2,3,...100] 变成 [[1,2,3],[4,5,6]....[100]]list = [x for x in range(1,101)]
print(list)list1=[list[x:x+3] for x in range(1,len(list)) if x % 3 == 0]
print(list1)

六、高级变量类型的公共语法

1. 内置函数

高级变量类型有一些公共的内置函数,如下

函数

描述

备注

len(items)

计算容器中元素个数

del item

删除变量

max(items)

返回容器中元素最大值

字典只比较key

min(items)

返回容器中元素最小值

字典只比较key

len 长度

str = 'hello'
print(len(str))

结果:

5

del 删除

lst = [1,2,3]
del lst[0]
print(lst)

结果:

[2,3]

2. 运算符

运算符

描述

支持的数据类型

+

合并

字符串、列表、元组

*

重复

字符串、列表、元组

in

是否存在(字典中判断键)

字符串、列表、元组、集合、字典

not in

是否不存在(字典中判断键)

字符串、列表、元组、集合、字典

> >= == < <=

比较(==以外的较少使用,逐个比较元素)

字符串、列表、元组

2.1. innot in

str = 'hello'
# h是否在str中
result = 'h' in str
print(result)
result = 'h' not in str
print(result)

结果:

True
False

2.2. +合并

只有字符串、列表、元组可以合并

  • 字符串
# 字符串
str1 = 'hello'
str2 = 'world'
str = str1 + str2
  • 列表
lst1 = [1,2,3]
lst2 = [4,5,6]
lst = lst1 + lst2
  • 元组
t1 = (1,2,3)
t2 = (4,5,6)
t = t1 + t2

2.3. * 重复

只有字符串、列表、元组可以

str = 'hello'
print(str*3)l = [1,2,3]
print(l * 3)t = (1,2,3)
print(t * 3)

结果:

hellohellohello
[1, 2, 3, 1, 2, 3, 1, 2, 3]
[1, 2, 3, 1, 2, 3, 1, 2, 3]

这篇关于python 入门第三天(高级进阶:str、set、dict、slice、推导式、高级变量类型的公共语法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/933359

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

c++ 类成员变量默认初始值的实现

《c++类成员变量默认初始值的实现》本文主要介绍了c++类成员变量默认初始值,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录C++类成员变量初始化c++类的变量的初始化在C++中,如果使用类成员变量时未给定其初始值,那么它将被

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

基于Python实现一个图片拆分工具

《基于Python实现一个图片拆分工具》这篇文章主要为大家详细介绍了如何基于Python实现一个图片拆分工具,可以根据需要的行数和列数进行拆分,感兴趣的小伙伴可以跟随小编一起学习一下... 简单介绍先自己选择输入的图片,默认是输出到项目文件夹中,可以自己选择其他的文件夹,选择需要拆分的行数和列数,可以通过

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker