Python自动化办公应用学习笔记21—元组的基本操作

一、序列通用操作(12个元组全部支持)

以下12个操作符和函数适用于所有序列类型(包括元组、列表、字符串):

操作/函数

描述

元组示例

结果

x in s

检查元素是否存在

3 in (1, 2, 3)

True

x not in s

检查元素是否不存在

4 not in (1, 2, 3)

True

s + t

连接两个序列

(1,2) + (3,4)

(1,2,3,4)

s * n

复制序列n次

('Hi',) * 3

('Hi','Hi','Hi')

s[i]

索引访问

('a','b','c')[1]

'b'

s[i:j]

切片(含i不含j)

(10,20,30,40)[1:3]

(20,30)

s[i:j:k]

带步长的切片

(0,1,2,3,4,5)[1:5:2]

(1,3)

len(s)

获取元素个数

len(('x','y'))

2

min(s)

获取最小元素

min((5, 2, 8))

2

max(s)

获取最大元素

max(('A','B','a'))

'a'(ASCII值)

s.index(x)

返回x首次出现的索引

('a','b','a','c').index('a')

0

s.count(x)

返回x出现次数

(1,1,2,3,1).count(1)

3

注意:所有切片操作返回新元组(因元组不可变)

1. 支持全部12种序列操作:索引/切片/连接/计数等

2. 禁止修改操作:无append()/pop()/remove()等方法

3. 切片返回新元组t[1:3] 创建新对象

4. 高效安全:适合存储配置、常量等不变数据

5. 解包特性x, y = (10, 20) 快速赋值

当需要修改数据时,转换为列表。

二、创建元组(4种方式)

# 1. 标准创建

colors = ("red", "green", "blue")

print(colors) # ('red', 'green', 'blue')


# 2. 单元素元组(必须加逗号!)

single = ("Python",)

print(type(single)) # <class 'tuple'>


# 3. 隐式创建(省略括号)

languages = "Java", "C++", "Python"

print(languages) # ('Java', 'C++', 'Python')


# 4. 从其他序列转换

nums_tuple = tuple([1, 2, 3]) # 列表转元组

print(nums_tuple) # (1, 2, 3)

三、基本操作(8大核心操作)

t1 = (1, 2, 3)

t2 = ('a', 'b')


# 1. 连接

combined = t1 + t2

print(combined) # (1, 2, 3, 'a', 'b')


# 2. 复制

tripled = t2 * 3

print(tripled) # ('a', 'b', 'a', 'b', 'a', 'b')


# 3. 成员检查

print(2 in t1) # True

print('x' not in t2) # True


# 4. 长度测量

print(len(t1)) # 3


# 5. 极值查找

nums = (15, 8, 42, 4)

print(max(nums)) # 42

print(min(nums)) # 4


# 6. 元素定位

letters = ('a', 'b', 'c', 'a', 'b')

print(letters.index('c')) # 2 (首次出现位置)

print(letters.index('b', 2)) # 4 (从索引2开始查找)


# 7. 元素计数

print(letters.count('a')) # 2


# 8. 元组解包

x, y, z = t1

print(f"x={x}, y={y}, z={z}") # x=1, y=2, z=3

四、办公自动化实战案例

场景:员工信息处理

# 元组存储员工信息

employees = (

("E1001", "张三", "销售部", 8500),

("E1002", "李四", "技术部", 12000),

("E1003", "王五", "行政部", 7500)

)


# 1. 查找最高薪资员工

max_salary = max(emp[3] for emp in employees)

top_earner = [emp for emp in employees if emp[3] == max_salary][0]

print(f"最高薪资员工:{top_earner[1]},薪资:{top_earner[3]}")


# 2. 按部门统计人数

dept_count = {}

for emp in employees:

dept = emp[2]

dept_count[dept] = dept_count.get(dept, 0) + 1

print("部门统计:", dept_count)


# 3. 生成员工邮箱

for emp in employees:

emp_id, name, dept, _ = emp # 解包忽略薪资

email = f"{name}.{emp_id}@company.com"

print(f"{name}的邮箱:{email}")

原文链接:,转发请注明来源!