Python 基础再升级!5 个超实用小技巧,写代码快人一步

刚入门 Python 能实现功能,但想让代码更简洁、更高效?这 5 个进阶偏基础的小技巧,看似简单却能大幅提升编码体验,每个都附可直接运行的示例,新手也能轻松掌握~

1. 巧用 enumerate:遍历列表同时获取索引

遍历列表时想知道元素的位置,不用手动加计数器,enumerate() 能直接返回索引和元素,还能自定义起始索引。

python 复制代码
# 待遍历的列表
fruits = ["苹果", "香蕉", "橙子", "葡萄"]

# 基础用法:默认从0开始
for idx, fruit in enumerate(fruits):
    print(f"索引{idx}:{fruit}")

# 进阶用法:指定起始索引(比如从1开始)
print("\n指定起始索引:")
for idx, fruit in enumerate(fruits, start=1):
    print(f"第{idx}个水果:{fruit}")

# 输出:
# 索引0:苹果
# 索引1:香蕉
# 索引2:橙子
# 索引3:葡萄
# 
# 指定起始索引:
# 第1个水果:苹果
# 第2个水果:香蕉
# 第3个水果:橙子
# 第4个水果:葡萄

2. zip () 函数:多列表同步遍历,超省心

需要同时遍历多个列表的对应元素时,zip() 能把多个可迭代对象打包成元组,避免手动处理索引。

python 复制代码
# 多个关联列表
names = ["张三", "李四", "王五"]
scores = [85, 92, 78]
subjects = ["数学", "语文", "英语"]

# 同步遍历三个列表
for name, score, subject in zip(names, scores, subjects):
    print(f"{name}的{subject}成绩:{score}分")

# 输出:
# 张三的数学成绩:85分
# 李四的语文成绩:92分
# 王五的英语成绩:78分

3. 用 set 快速去重:比列表遍历高效 N 倍

列表去重不用写循环判断,转成集合(set)再转回列表,一行就能搞定,且时间复杂度更低。

python 复制代码
# 含重复元素的列表
nums = [1, 2, 2, 3, 3, 3, 4, 4, 5]

# 快速去重
unique_nums = list(set(nums))
print("去重后:", unique_nums)  # 输出:去重后:[1, 2, 3, 4, 5]

# 拓展:保持原列表顺序(Python 3.7+)
unique_nums_ordered = list(dict.fromkeys(nums))
print("去重且保序:", unique_nums_ordered)  # 输出:去重且保序:[1, 2, 3, 4, 5]

4. 三元表达式:简化简单的条件判断

简单的 if-else 赋值逻辑,用三元表达式能精简代码,保持可读性的同时减少行数。

python 复制代码
# 需求:判断成绩是否及格,返回对应提示
score = 88

# 传统if-else写法
if score >= 60:
    result = "及格"
else:
    result = "不及格"

# 三元表达式写法
result = "及格" if score >= 60 else "不及格"
print(f"成绩{score}:{result}")  # 输出:成绩88:及格

# 进阶:嵌套三元表达式(适用于简单场景)
score = 95
result = "优秀" if score >= 90 else "良好" if score >= 80 else "及格" if score >= 60 else "不及格"
print(f"成绩{score}:{result}")  # 输出:成绩95:优秀

5. with 语句:自动管理文件 / 资源,告别忘记 close ()

操作文件时用with语句,无需手动调用close(),代码块执行完会自动关闭文件,避免资源泄露。

python 复制代码
# 传统写法(需手动close)
f = open("test.txt", "w", encoding="utf-8")
f.write("Python基础进阶技巧")
f.close()

# with语句写法(推荐)
with open("test.txt", "r", encoding="utf-8") as f:
    content = f.read()
    print("文件内容:", content)  # 输出:文件内容:Python基础进阶技巧

# 注:with语句块结束后,文件会自动关闭,即使报错也不影响

总结

  1. enumerate() 遍历带索引、zip() 同步遍历多列表,解决遍历场景的常见痛点;
  2. 集合(set)快速去重效率高,三元表达式简化简单条件赋值;
  3. with 语句自动管理资源,操作文件 / 网络连接时更安全。
相关推荐
Zhansiqi1 天前
day42部分题目
python
小王不爱笑1321 天前
IO 模型
开发语言·python
kishu_iOS&AI1 天前
Conda 简要说明与常用指令
python·安全·conda
小陈工1 天前
FastAPI性能优化实战:从每秒100请求到1000的踩坑记录
python·性能优化·django·flask·numpy·pandas·fastapi
知我Deja_Vu1 天前
【避坑指南】ConcurrentHashMap 并发计数优化实战
java·开发语言·python
njidf1 天前
用Python制作一个文字冒险游戏
jvm·数据库·python
呆呆小孩1 天前
Anaconda 被误删抢救手册:从绝望到重生
python·conda
liliangcsdn1 天前
LLM复杂数值的提取计算场景示例
人工智能·python
人工智能AI酱1 天前
【AI深究】逻辑回归(Logistic Regression)全网最详细全流程详解与案例(附大量Python代码演示)| 数学原理、案例流程、代码演示及结果解读 | 决策边界、正则化、优缺点及工程建议
人工智能·python·算法·机器学习·ai·逻辑回归·正则化
WangLanguager1 天前
逻辑回归(Logistic Regression)的详细介绍及Python代码示例
python·算法·逻辑回归