Python编程常用的35个经典案例

在这里插入图片描述

Python 的简洁和强大使其成为许多开发者的首选语言。本文将介绍35个常用的Python经典代码案例。这些示例覆盖了基础语法、常见任务、以及一些高级功能。

1.列表推导式

  • 这个例子展示了列表推导式,用于生成FizzBuzz序列。
fizz_buzz_list = 
["FizzBuzz" if i % 15 == 0 else "Fizz" if i % 3 == 0 else "Buzz" if i % 5 == 0 else i for i in range(1, 101)]   
print(fizz_buzz_list)   

2.使用"with"语句和"csv"模块读取CSV文件

  • "csv"模块是处理CSV文件的利器,与"with"语句结合可以确保文件正确关闭。
import csv      
with open('data.csv', mode='r') as file:csvFile = csv.reader(file)       
for row in csvFile:           
print(row)   

3.正则表达式查找字符串

  • 正则表达式是强大的文本匹配工具,这里用来找出字符串中的所有单词。
import re pattern = r'\b[A-Za-z][A-Za-z0-9_]*\b'   
text = "Hello, this is a test string with username: JohnDoe"   
matches = re.findall(pattern, text)   
print(matches)   

4.计算字符串中某个字符的数量

  • "count()"方法可以快速统计子串在字符串中的出现次数。
text = "Hello, World!"char = "l"   
count = text.count(char)   
print(f"The character '{char}' appears {count} times.")   

5.使用set进行去重

  • 集合(set)是一个无序不重复的元素集,非常适合去重。
duplicates = [1, 2, 2, 3, 4, 4, 5]   
unique_list = list(set(duplicates))   
print(unique_list)   

6.使用"format()"格式化字符串

  • "format()"方法使字符串格式化更加灵活和清晰。
name = "John"age=30   
print("My name is {} and I am {} years old.".format(name, age))   

7.实现一个简单的缓存装饰器

  • 装饰器可以用来缓存函数的结果,提高性能。
def cache(func):cache_dict = {}
def wrapper(num):if num in cache_dict: 
return cache_dict[num]
else:val = func(num)cache_dict[num] = val               
return val       
return wrapper @cache   
def fibonacci(n):if n < 2:           
return n       
return fibonacci(n-1) + fibonacci(n-2)  print(fibonacci(10))   

8.使用"try-except-else-finally"处理异常

  • 完整的异常处理流程可以让我们更好地控制程序执行。
try:result = 10 / 0   
except ZeroDivisionError:       
print("Cannot divide by zero")   
else:       
print("Result is:", result)   
finally:       
print("Execution complete.")   

9.断言(assertion)的使用

  • 断言可以帮助我们在开发阶段捕捉到错误条件。
def divide(a, b):       
assert b != 0, "Division by zero is not allowed"       
return a / b   
print(divide(10, 0))   

10.路径操作

  • "os.path"模块提供了许多实用的路径操作函数。
import os path = "/path/to/some/file.txt"   
dirname = os.path.dirname(path)   
basename = os.path.basename(path)   
print("Directory:", dirname)   
print("Basename:", basename)   

11.环境变量的读取和设置

  • "os.environ"允许我们访问和修改环境变量。
import os # 读取环境变量   
print("PATH:", os.environ["PATH"]) # 设置环境变量   
os.environ["NEW_VAR"] = "NewValue"   
print("NEW_VAR:", os.environ["NEW_VAR"])   

12.使用"itertools"模块

  • "itertools"模块提供了一系列用于创建迭代器的函数,非常有用。
import itertools      
for combination in itertools.combinations([1, 2, 3], 2):       
print(combination)   

13.日期时间计算和操作

  • 日期时间计算是常见的需求,"datetime"模块提供了丰富的类和方法。
from datetime 
import datetime, timedelta      
now = datetime.utcnow()   
one_day = timedelta(days=1)   
yesterday = now - one_day   
print("Yesterday's date:", yesterday)   

14.排序和反序列表

  • 列表对象自带的"sort()"和"reverse()"方法可以方便地对列表进行排序和反序。
numbers = [3, 1, 4, 1, 5, 9, 2, 6]   
numbers.sort()   
print("Sorted:", numbers)   
numbers.reverse()   
print("Reversed:", numbers)   

15.使用"json"模块处理JSON数据

  • "json"模块使得Python处理JSON数据变得简单。
import 
json data = {"name": "John", "age": 30}   
json_data = json.dumps(data)   
print(json_data)   
parsed_data = json.loads(json_data)   
print(parsed_data)   

16.使用"collections"模块的"defaultdict"

  • "defaultdict"是字典的一个子类,它提供了一个默认值,用于字典中尝试访问不存在的键。
from collections 
import defaultdict      
dd = defaultdict(int)   
dd["apple"] = 1   
dd["banana"] = 2   
print(dd["apple"])  # 输出:1   
print(dd["orange"])  # 输出: 0,不存在的键返回默认值0   

17.使用"functools"模块的"reduce"函数

  • "reduce"函数可以将一个二元函数累积地应用到一个序列的元素上,从左到右,以便将序列减少为单个值。
from functools 
import reduce   
from operator 
import add   
numbers = [1, 2, 3, 4]   
total = reduce(add, numbers)   
print(total)  # 输出:10   

18.使用"threading"模块进行简单的多线程编程

  • "threading"模块允许我们创建和管理线程,这是实现并发的一种方式。
import threading      
def print_numbers():       
for i in range(10):           
print(i)   
thread = threading.Thread(target=print_numbers)   
thread.start()   
thread.join()   

19.使用"multiprocessing"模块进行多进程编程

  • "multiprocessing"模块是Python中进行进程编程的关键模块。
from multiprocessing 
import Process, cpu_count      
def print_hello():       
print("Hello from child process")   
if __name__ == '__main__':       
processes = []       
for _ in range(cpu_count()):           
p=Process(target=print_hello)           
p.start()           
processes.append(p)       
for p in processes:           
p.join()  

20.使用"requests"模块进行HTTP请求

  • "requests"模块简化了HTTP请求的相关操作,是进行网络编程的好帮手。
import requests      
response = requests.get("https://www.example.com")  print(response.status_code)   print(response.text) 

21.使用map()函数将字符串转换为整数列表

  • "map()"函数可以对一个序列的每个元素应用指定的函数。
string_numbers = "1 2 3 4 5"   
numbers = list(map(int, string_numbers.split()))   
print(numbers)   

22.条件语句

  • 条件语句是控制程序流程的基本构建块。
x = 7   if x > 5:       
print("x is greater than 5")   
else:       
print("x is less than or equal to 5")   

23.for循环遍历列表

  • "for"循环在Python中是常用的迭代工具。
fruits = ["apple", "banana", "cherry"]   
for fruit in fruits:       
print(fruit)   

24.while循环

  • "while"循环允许程序按条件重复执行代码。
count = 0   
while count < 5:       
print(count)       
count += 1   

25.使用"enumerate()"获取列表的索引和值

  • "enumerate()"函数可以同时获得元素的索引和值,使代码更简洁。
for index, value in enumerate(["apple", "banana", "cherry"]):       
print(index, value) 

26.列表切片

  • 列表切片是访问列表子集的一种快捷方式。
fruits = ["apple", "banana", "cherry", "date", "elderberry"]   
print(fruits[1:4])   

27.字符串格式化

  • 字符串格式化是Python中处理字符串的重要方法。
name = "John"   
age = 30   
print(f"My name is {name} and I am {age} years old.") 

28.异常处理

  • 异常处理可以帮助我们捕获和处理错误。
try: result = 10 / 0   
except ZeroDivisionError:       
print("Cannot divide by zero")   

29.类定义

  • 类的使用是面向对象编程的核心。
class Person:
def __init__(self, name, age):
self.name = name 
self.age = age      
def greet(self):           
print(f"Hello, my name is {self.name} and I am {self.age} years old.")   

30.集合并集

  • 集合操作可以方便地处理一组唯一的元素。
fruits_set = {"apple", "banana", "cherry"}   
veggies_set = {"carrot", "broccoli", "banana"}   
print(fruits_set | veggies_set)   

31.创建字典

  • 字典是存储键值对的数据结构。
person_dict = {"name": "John", "age": 30, "city": "New York"}   
print(person_dict)   

32.访问字典值

  • 通过键来访问字典中的值。
person_dict = {"name": "John", "age": 30, "city": "New York"}   
print(person_dict["name"])   

33.删除字典元素

  • 在字典中删除元素同样容易。
person_dict = {"name": "John", "age": 30, "city": "New York"}   
del person_dict["age"]   
print(person_dict)   

34.生成器函数

  • 生成器可以创建迭代器,按需产生值。
def countdown(n):       
while n > 0:           
yield n n -= 1   
for i in countdown(5):       
print(i)   

35.使用zip()同时遍历多个列表

  • 使用"zip()"可以方便地并行迭代多个序列。
names = ["Alice", "Bob", "Charlie"]   
ages = [25, 30, 35]   
for name, age in zip(names, ages):       
print(name, age)   

图片

总结

  • 最后希望你编程学习上不急不躁,按照计划有条不紊推进,把任何一件事做到极致,都是不容易的,加油,努力!相信自己!

文末福利

  • 最后这里免费分享给大家一份Python全套学习资料,希望能帮到那些不满现状,想提升自己却又没有方向的朋友,也可以和我一起来学习交流呀。

包含编程资料、学习路线图、源代码、软件安装包等!【[点击这里]】领取!

  • ① Python所有方向的学习路线图,清楚各个方向要学什么东西
  • ② 100多节Python课程视频,涵盖必备基础、爬虫和数据分析
  • ③ 100多个Python实战案例,学习不再是只会理论
  • ④ 华为出品独家Python漫画教程,手机也能学习

可以扫描下方二维码领取【保证100%免费

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1555906.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

ultralytics yolo pose 示例:加载官方pose模型进行推理

Ultralytics YOLO 是计算机视觉和 ML 领域专业人士的高效工具。 安装 ultralytics 库&#xff1a; pip install ultralytics 官方YoLo Pose 模型列表信息&#xff1a; 实现代码如下&#xff1a; from ultralytics import YOLO import cv2 # Load a model ckpt_dir "…

HTB:Ignition[WriteUP]

目录 连接至HTB服务器并启动靶机 1.Which service version is found to be running on port 80? 2.What is the 3-digit HTTP status code returned when you visit http://{machine IP}/? 3.What is the virtual host name the webpage expects to be accessed by? 4.…

详细解释:前向传播、反向传播等

详细解释:前向传播、反向传播等 在机器学习和深度学习中,**前向传播(Forward Propagation)和反向传播(Backward Propagation)**是训练神经网络的两个核心过程。理解这两个概念对于掌握神经网络的工作原理、优化方法以及模型微调技术(如LoRA、P-tuning等)至关重要。以下…

机器人技术基础(1-3章坐标变换)

位置矢量的意思是B坐标系的原点O相对于A坐标系的平移变换后的矩阵&#xff1a; 齐次坐标最后一个数表示缩放倍数&#xff1a; 左边的是T形变换矩阵&#xff0c;右边的是需要被变换的矩阵&#xff1a;T形变换矩阵的左上角表示旋转&#xff0c;右上角表示平移&#xff0c;左下角最…

好用且不伤眼镜的超声波清洗机排名!谁才是清洁小能手?

对于经常佩戴眼镜的人来说&#xff0c;眼镜的日常清洁保养极为关键。传统清洁方式可能导致镜片刮花和残留污渍&#xff0c;鉴于此&#xff0c;眼镜专用的超声波清洗机应运而生&#xff0c;利用超声振动技术深入微细缝隙&#xff0c;彻底扫除污垢与油脂&#xff0c;保护镜片免受…

JavaEE: 数据链路层的奇妙世界

文章目录 数据链路层以太网源地址和目的地址 类型数据认识 MTU 数据链路层 以太网 以太网的帧格式如下所示: 源地址和目的地址 源地址和目的地址是指网卡的硬件地址(也叫MAC地址). mac 地址和 IP 地址的区别: mac 地址使用6个字节表示,IP 地址4个字节表示. 一般一个网卡,在…

Unity3D 单例模式

Unity3D 泛型单例 单例模式 单例模式是一种创建型设计模式&#xff0c;能够保证一个类只有一个实例&#xff0c;提供访问实例的全局节点。 通常会把一些管理类设置成单例&#xff0c;例如 GameManager、UIManager 等&#xff0c;可以很方便地使用这些管理类单例&#xff0c;…

BM1 反转链表

要求 代码 /*** struct ListNode {* int val;* struct ListNode *next;* };*/ /*** 代码中的类名、方法名、参数名已经指定&#xff0c;请勿修改&#xff0c;直接返回方法规定的值即可*** param head ListNode类* return ListNode类*/ struct ListNode* ReverseList(struct …

从零开始讲PCIe(10)——事务层介绍

一、事务层概述 事务层在响应软件层的请求时&#xff0c;会生成出站数据包。同时&#xff0c;它也会检查入站数据包&#xff0c;并将其中包含的信息传递到软件层。事务层支持非发布事务的分割事务协议&#xff0c;能够将入站的完成数据包与之前传输的非发布请求相关联。该层处理…

After-kaoyan

知乎 - 安全中心 有态度&#xff0c;有回应&#xff0c;有温度&#xff0c;是跟双鱼相处的基础 我今天跟大家泄漏一个秘密&#xff0c;这个秘密也很简单&#xff0c;就是我每次遇到困难险阻时候我从不退缩&#xff0c;我也不会想着&#xff1a;“算了吧&#xff0c;我做不到&a…

C/C++/EasyX——入门图形编程(5)

【说明】友友们好&#xff0c;今天来讲一下键盘消息函数。&#xff08;其实这个本来准备和鼠标消息函数放在一起的&#xff0c;但是上一篇三个放在一起&#xff0c;内容就有点多了&#xff0c;只写一个又太单调了&#xff0c;所以键盘消息函数的内容就放在这一篇了 (^&#xff…

用manim实现Gram-Schmidt正交化过程

在线性代数中&#xff0c;正交基有许多美丽的性质。例如&#xff0c;由正交列向量组成的矩阵(又称正交矩阵)可以通过矩阵的转置很容易地进行反转。此外&#xff0c;例如&#xff1a;在由彼此正交的向量张成的子空间上投影向量也更容易。Gram-Schmidt过程是一个重要的算法&#…

Oracle 表空间异构传输

已经有了表空间的数据文件&#xff0c;和元数据dump文件&#xff0c;如何把这个表空间传输到异构表空间中&#xff1f; 查询异构传输平台信息&#xff1a; COLUMN PLATFORM_NAME FORMAT A40 SELECT PLATFORM_ID, PLATFORM_NAME, ENDIAN_FORMAT FROM V$TRANSPORTABLE_PLATFORM O…

LLM大模型:开源RAG框架汇总

前言 本文搜集了一些开源的基于LLM的RAG&#xff08;Retrieval-Augmented Generation&#xff09;框架&#xff0c;旨在吸纳业界最新的RAG应用方法与思路。如有错误或者意见可以提出&#xff0c;同时也欢迎大家把自己常用而这里未列出的框架贡献出来&#xff0c;感谢~ RAG应用…

【Python】数据可视化之聚类图

目录 clustermap 主要参数 参考实现 clustermap sns.clustermap是Seaborn库中用于创建聚类热图的函数&#xff0c;该函数能够将数据集中的样本按照相似性进行聚类&#xff0c;并将聚类结果以矩阵的形式展示出来。 sns.clustermap主要用于绘制聚类热图&#xff0c;该热图通…

训练验证器解决数学应用题

人工智能咨询培训老师叶梓 转载标明出处 数学问题解决不仅要求模型能够理解问题的语言表述&#xff0c;还要求其能够准确地执行一系列数学运算&#xff0c;每一步的准确性都至关重要。遗憾的是&#xff0c;现有的语言模型在这一领域的性能远远未能达到人类的水平&#xff0c;它…

[C#]使用onnxruntime部署yolov11-onnx实例分割模型

【官方框架地址】 https://github.com/ultralytics/ultralytics.git 【算法介绍】 在C#中使用ONNX Runtime部署YOLOv11-ONNX实例分割模型&#xff0c;涉及到模型的加载、数据预处理、模型推理和后处理几个关键步骤。 首先&#xff0c;需要确保已经安装了ONNX Runtime的NuGe…

站岗放哨树形dp

前言&#xff1a;好久没有写树上dp了&#xff0c;这儿题目还是挺有意思的 题目地址 #include<bits/stdc.h> #include<iostream> using namespace std;//#define int long long int n; const int N (int)1e510; int e[N],ne[N],h[N],idx 0; int dp[2][N];void add…

FLUX1.1PRO震撼来袭:蓝莓揭开神秘面纱,4网站体验,6倍卓越速率和更高质量,竞技场角逐超越所有模型,Elo最高分

大家好我是安琪&#xff01;&#xff01;&#xff01; FLUX 1.1 PRO震撼来袭&#xff1a;蓝莓揭开神秘面纱&#xff0c;4网站体验&#xff0c;6倍卓越速率和更高质量&#xff0c;竞技场角逐超越所有模型&#xff0c;Elo最高分 在人工智能领域&#xff0c;图像生成与反推技术的…

登 Nature 子刊!论文一作详解蛋白质语言模型的小样本学习方法,解决湿实验数据匮乏难题

在「Meet AI4S」系列直播第三期中&#xff0c;我们有幸邀请到了上海交通大学自然科学研究院 & 上海国家应用数学中心博士后周子宜&#xff0c; 他所在的上海交通大学洪亮课题组研究方向主要为 AI 蛋白和药物设计、分子生物物理。该课题组研究成果颇丰&#xff0c;截止目前共…