使用 Python3 进行文字识别技术的初步入门

发布时间: 2024-02-15 15:54:16 阅读量: 29 订阅数: 21
# 1. 介绍 ## 1.1 文字识别技术的概述 文字识别技术,又称为光学字符识别(OCR,Optical Character Recognition),是一种将图像中的文字信息转换为可编辑文本的技术。随着数字化时代的来临,文字识别技术在很多领域得到了广泛应用,如自动化办公、图像处理、自然语言处理等。 文字识别技术的基本原理是通过图像处理算法将输入的图像转换为数字化的图像,并通过模式匹配、特征提取等技术,将图像中的文字信息识别出来。这项技术的核心挑战在于处理不同字体、大小、形状和背景干扰的文字,并使其能够准确地识别。 ## 1.2 Python3 在文字识别中的应用 Python3作为一门强大而简洁的编程语言,也在文字识别领域得到了广泛应用。Python3提供了丰富的图像处理库和文字识别库,使得开发者可以轻松地实现文字识别的各个环节。 在Python中,我们可以利用Pillow库进行图像的读取、处理和保存,使用OpenCV库进行图像的增强和分割,利用Tesseract库调用OCR引擎进行文字识别等。此外,Python还有其他第三方库和工具,如百度AI开放平台、谷歌云视觉API等,提供了快速、准确的文字识别功能。 Python3不仅具有简洁易懂的语言特性,还有庞大的开源社区支持和丰富的第三方库,在文字识别领域有着广泛的应用前景。与其他编程语言相比,Python3以其强大的生态系统和易用性,成为开发者们首选的语言之一。在接下来的章节中,我们将介绍如何在Python3中安装和配置文字识别所需的库,并通过实例演示文字识别的实际应用。 # 2. 安装和配置 在开始进行文字识别之前,我们需要安装和配置相关的环境。本章节将引导您完成Python3的安装和文字识别库的安装,并配置好文字识别环境。 ### 2.1 安装 Python3 Python3是一门功能强大且易于学习的编程语言,广泛应用于文字识别领域。以下是在不同操作系统上安装Python3的步骤: #### 2.1.1 Windows 1. 打开Python官方网站 (https://www.python.org) 的下载页面。 2. 点击下载按钮,并选择适用于Windows的最新版本的Python安装程序。 3. 运行下载的安装程序,选择"Install Now"选项并按照默认设置完成安装。 #### 2.1.2 macOS 1. 打开Python官方网站 (https://www.python.org) 的下载页面。 2. 点击下载按钮,并选择适用于macOS的最新版本的Python安装程序。 3. 运行下载的安装程序,按照向导完成安装。 #### 2.1.3 Linux 许多Linux发行版已经预装了Python。如果您的系统没有预装Python或者需要更新到最新版本,请执行以下命令: ```shell $ sudo apt-get update $ sudo apt-get install python3 ``` ### 2.2 安装文字识别库 Python提供了许多用于文字识别的库,我们可以根据需要选择适合的库。下面是一些常用的文字识别库: - **Tesseract**: Tesseract是一个开源的OCR引擎,能够将图像中的文本转换为可编辑和可搜索的文本。要安装Tesseract,请使用以下命令: ```shell $ sudo apt-get install tesseract-ocr $ pip install pytesseract ``` - **OpenCV**: OpenCV是一个广泛使用的计算机视觉库,它提供了许多图像处理和文字识别的功能。要安装OpenCV,请使用以下命令: ```shell $ pip install opencv-python ``` - **Pillow**: Pillow是一个用于图像处理的Python库,它提供了许多方便的图像处理功能。要安装Pillow,请使用以下命令: ```shell $ pip install pillow ``` 请根据需要选择安装相应的库。 ### 2.3 配置文字识别环境 安装完文字识别库后,我们需要配置相应的环境才能正常进行文字识别。以下是一些常见的环境配置步骤: #### 2.3.1 配置Tesseract环境 如果您选择使用Tesseract进行文字识别,请确保已经成功安装Tesseract,并将其可执行文件路径添加到系统的环境变量中。 在Windows中,您可以按照以下步骤进行设置: 1. 搜索并打开"环境变量"。 2. 在"系统变量"部分,找到名为"Path"的变量,并点击"编辑"。 3. 点击"新建",并将Tesseract的可执行文件路径添加到列表中。 在macOS和Linux中,您可以按照以下步骤进行设置: 1. 打开终端并运行以下命令编辑配置文件: ```shell $ nano ~/.bashrc ``` 2. 在文件末尾添加以下行,并保存退出: ```shell export TESSDATA_PREFIX=/usr/share/tesseract-ocr/4.00/tessdata export PATH=$PATH:/usr/local/bin ``` 注意:根据您的实际安装路径进行相应的更改。 完成了Python环境和文字识别库的安装和配置后,我们就可以开始进行文字识别的开发工作了。在接下来的章节中,我们将学习如何进行图像预处理、文字识别算法的实现以及应用案例的探索。 # 3. 图像预处理 在文字识别任务中,图像预处理是非常重要的一步,它可以帮助我们优化图像质量,提高文字识别的准确性。本章节将介绍如何使用Python3来进行图像预处理的相关操作。 ### 3.1 图像读取和处理 首先,我们需要使用Python3的图像处理库PIL(Pillow)来读取和处理图像。首先,我们需要安装Pillow库,可以使用以下命令来安装: ``` pip install pillow ``` 安装完成后,我们可以使用如下代码来读取图像: ```python from PIL import Image # 读取图像 image = Image.open('image.jpg') # 显示图像 image.show() ``` 在读取图像之后,我们可以对图像进行一些常用的处理操作,如调整图像大小、调整亮度和对比度、旋转和翻转等。下面是一些示例代码: ```python # 调整图像大小 resized_image = image.resize((800, 600)) # 调整亮度和对比度 enhanced_image = image.enhance(brightness=1.5, contrast=1.2) # 旋转图像 rotated_image = image.rotate(90) # 翻转图像 flipped_image = image.transpose(Image.FLIP_LEFT_RIGHT) ``` ### 3.2 图像去噪和增强 图像去噪和增强是图像预处理中的重要步骤,可以帮助我们去除图像中的噪声和增强图像的细节。常用的图像去噪和增强算法包括中值滤波、高斯滤波和直方图均衡化等。以下是一个示例代码: ```python from PIL import ImageFilter # 中值滤波 denoised_image = image.filter(ImageFilter.MedianFilter) # 高斯滤波 blurred_image = image.filter(ImageFilter.GaussianBlur(radius=2)) # 直方图均衡化 equalized_image = image.equalize() ``` 除了上述方法之外,还可以使用其他图像处理算法来去噪和增强图像,具体选择哪种算法需要根据实际情况来决定。 ### 3.3 图像分割和归一化 在进行文字识别之前,我们通常需要对图像进行分割和归一化操作。图像分割可以将图像中的文字区域与背景区域进行分离,以便更好地识别文字。常用的图像分割算法包括阈值分割、边缘检测和连通区域分析等。以下是一个示例代码: ```python # 图像阈值分割 threshold = 100 binary_image = image.convert('L').point(lambda x: 255 if x > threshold else 0, mode='1') # 边缘检测 canny_image = image.filter(ImageFilter.FIND_EDGES) # 连通区域分析 regions = binary_image.getregions() ``` 图像归一化是指将图像转换为统一的尺寸和颜色空间,以便进行后续的文字识别操作。常用的图像归一化方法包括缩放、灰度化和二值化等。以下是一个示例代码: ```python # 图像缩放 normalized_image = image.resize((200, 200)) # 灰度化 gray_image = image.convert('L') # 二值化 threshold = 100 binary_image = gray_image.point(lambda x: 255 if x > threshold else 0, mode='1') ``` 图像分割和归一化的具体方法和参数需要根据实际情况来调整,以获得最佳的文字识别效果。 本章节介绍了如何使用Python3进行图像预处理的相关操作,包括图像读取和处理、图像去噪和增强、图像分割和归一化等。这些操作可以帮助我们优化图像质量,提高文字识别的准确性。在下一章节中,我们将介绍文字识别的算法原理和实现方法。 # 4. 文字识别算法 文字识别是将图像中的文字转换为可编辑和可搜索的文本的过程。在实现文字识别的过程中,有多种算法可以选择,本章将介绍两种常见的文字识别算法:基于模板匹配的文字识别和基于OCR引擎的文字识别。 ##### 4.1 基于模板匹配的文字识别 基于模板匹配的文字识别算法是一种简单而有效的文字识别方法。它通过预先准备好的字符模板与待识别图像进行匹配,从而找到最佳匹配的字符。 下面是一个使用Python3实现基于模板匹配的文字识别的示例代码: ```python import cv2 import numpy as np # 读取字符模板 template_images = [] for i in range(10): image = cv2.imread(f"template_{i}.png", 0) template_images.append(image) # 读取待识别图像 image = cv2.imread("image.png", 0) # 对待识别图像进行字符匹配 result = "" for y in range(0, image.shape[0], template_images[0].shape[0]): for x in range(0, image.shape[1], template_images[0].shape[1]): # 提取待匹配字符图像 roi = image[y:y + template_images[0].shape[0], x:x + template_images[0].shape[1]] # 计算每个字符与模板的匹配度 match_scores = [] for template_image in template_images: match_scores.append(cv2.matchTemplate(roi, template_image, cv2.TM_CCOEFF_NORMED)) # 选择匹配度最高的字符 best_match = np.argmax(match_scores) result += str(best_match) # 输出识别结果 print(f"识别结果:{result}") ``` 以上示例代码中,首先读取了预先准备好的字符模板和待识别的图像。然后,通过遍历待识别图像中的每个字符区域,提取出字符图像,然后与字符模板进行匹配。最后,选择匹配度最高的字符作为识别结果。 ##### 4.2 基于OCR引擎的文字识别 基于OCR(Optical Character Recognition,光学字符识别)引擎的文字识别算法是目前最常用和高效的文字识别方法之一。OCR引擎使用先进的图像处理和模式识别算法,可以自动识别和提取文字信息。 Python3中有多个优秀的OCR库可供使用,如Tesseract和Pytesseract。下面是一个使用Python3和Pytesseract实现基于OCR引擎的文字识别的示例代码: ```python import cv2 import pytesseract # 读取待识别图像 image = cv2.imread("image.png") # 预处理图像(例如去噪、增强等) processed_image = preprocess_image(image) # 使用Pytesseract进行文字识别 result = pytesseract.image_to_string(processed_image, lang="eng") # 输出识别结果 print(f"识别结果:{result}") ``` 以上示例代码中,首先使用OpenCV进行图像预处理,以提高文字识别的准确性。然后,利用Pytesseract库的`image_to_string`函数对预处理后的图像进行文字识别。最后,输出识别结果。 基于OCR引擎的文字识别算法具有较高的准确性和适应性,可以在各种复杂场景下进行文字识别,因此在实际应用中得到了广泛的应用。 # 5. 文字识别应用 ### 5.1 批量处理图片中的文本 在许多场景下,我们需要从一批图片中提取文本信息,例如从扫描文件中提取文字内容、从照片中提取文字等。使用文字识别技术可以方便地实现这一功能,并大幅提升处理效率。 下面是一个使用Python3进行批处理的示例代码: ```python import cv2 import pytesseract import os # 设置Tesseract引擎的路径 pytesseract.pytesseract.tesseract_cmd = 'C:/Program Files/Tesseract-OCR/tesseract.exe' # 图片路径 image_folder = 'input_images' output_folder = 'output_texts' # 创建输出文件夹 if not os.path.exists(output_folder): os.makedirs(output_folder) # 获取图片列表 image_list = os.listdir(image_folder) for image_file in image_list: # 读取图片 image_path = os.path.join(image_folder, image_file) image = cv2.imread(image_path) # 图像处理(可以根据需要进行去噪、增强等操作) # 文字识别 text = pytesseract.image_to_string(image, lang='eng') # 输出文本到文件 output_file = image_file.replace('.jpg', '.txt') output_path = os.path.join(output_folder, output_file) with open(output_path, 'w') as f: f.write(text) print(f'Successfully processed {image_file} and saved result to {output_file}') ``` 该示例使用了开源的Tesseract OCR引擎进行文字识别,要使用该引擎需要先安装并配置好。在代码中,我们首先设置了Tesseract引擎的路径,然后指定输入图片的文件夹和输出文本的文件夹。 接下来,我们遍历输入图片文件夹中的所有图片,读取每个图片并进行图像处理(根据需要进行去噪、增强等操作),然后使用pytesseract库的`image_to_string()`方法进行文字识别。最后,我们将识别结果保存到输出文本文件中。 运行上述代码后,会将每个图片中提取的文本信息保存为对应的文本文件,并打印出处理的结果。 ### 5.2 提取实时摄像头中的文字 文字识别不仅可以应用于静态图片,还可以应用于实时视频流中的文字提取。这在许多场景下非常有用,例如实时的车牌识别、实时监控视频中的文字提取等。 下面是一个使用Python3和OpenCV进行实时文字识别的示例代码: ```python import cv2 import pytesseract # 设置Tesseract引擎的路径 pytesseract.pytesseract.tesseract_cmd = 'C:/Program Files/Tesseract-OCR/tesseract.exe' # 打开摄像头(0代表默认摄像头) capture = cv2.VideoCapture(0) while True: # 读取每一帧图像 ret, frame = capture.read() # 图像处理(可以根据需要进行去噪、增强等操作) # 文字识别 text = pytesseract.image_to_string(frame, lang='eng') # 在图像中绘制识别结果 cv2.putText(frame, text, (50, 50), cv2.FONT_HERSHEY_SIMPLEX, 1, (0, 255, 0), 2) # 显示图像 cv2.imshow('Text Recognition', frame) # 按下q键退出循环 if cv2.waitKey(1) == ord('q'): break # 释放摄像头并关闭所有窗口 capture.release() cv2.destroyAllWindows() ``` 在上述代码中,我们先设置了Tesseract引擎的路径,然后打开了摄像头。在循环中,我们读取每一帧图像,并进行图像处理和文字识别。识别结果被绘制在原始图像上,并显示在窗口中。 通过按下键盘上的q键,我们可以退出循环并关闭所有窗口。 该示例可以实时提取摄像头中的文字信息,并显示在图像上,方便用户实时查看识别结果。 ### 5.3 文字识别在自然语言处理中的应用 文字识别技术在自然语言处理(NLP)中扮演着重要的角色。它可以将图片中的文字信息提取出来,并用于各种文字处理任务,如文本分类、文本摘要、文本翻译等。 例如,在进行情感分析时,我们可以使用文字识别技术从社交媒体上的图片中提取帖子内容,然后根据文本内容进行情感判断。又或者,在多语言翻译中,我们可以使用文字识别技术将图片中的文本内容提取出来,然后将其翻译成目标语言。 文字识别在自然语言处理中的应用不仅能够提升处理效率,还能够拓宽应用场景,为人们的日常生活和工作带来更多便利。 总之,文字识别技术可以应用于各种场景,如批量处理图片中的文本、提取实时摄像头中的文字等,并在自然语言处理中发挥重要作用,为人们提供了更多便捷的方式来处理和理解文字信息。 ## 6. 总结与展望 ### 6.1 文字识别的现状和挑战 文字识别技术在过去几年取得了巨大的进展,并取得了很多令人瞩目的成果。目前,文字识别已经在许多领域中得到了广泛应用,如办公自动化、图像处理、自然语言处理等。 然而,文字识别仍然面临一些挑战。例如,对于复杂的图像场景和特殊字体等,识别准确率可能会有所下降。另外,文字识别技术对于手写、大写字母等特殊形式的文字识别仍然存在一定难度。 ### 6.2 Python3 在文字识别技术中的未来发展 Python3作为一门功能强大且易于使用的编程语言,在文字识别技术中扮演着重要的角色。它提供了丰富的库和工具,如OpenCV、Tesseract、PyTorch等,可以方便地进行图像处理和文字识别。 未来,随着人工智能和深度学习等技术的不断发展,Python3在文字识别技术中的应用将会更加广泛和深入。我们可以期待更高的识别准确率、更快的处理速度以及更丰富的应用场景。同时,我们也需要不断学习和探索新的算法和技术,以应对文字识别领域中的新挑战。 总之,Python3在文字识别技术中发挥着重要作用,并具有广阔的发展前景。我们相信,在不久的将来,文字识别技术将会得到进一步的突破和应用,为人们带来更多的便利和创新。 # 6. 总结与展望 文字识别技术在现代社会中得到了广泛的应用,为人们的生活和工作带来了很大的便利。本文主要介绍了Python3在文字识别中的应用,并通过安装和配置相关环境,介绍了图像预处理和文字识别算法的实现。 总结一下,Python3在文字识别中的应用主要包括以下几个方面: 1. 安装和配置:首先需要安装Python3,并安装相关的文字识别库。然后,根据需要配置文字识别环境,如设置相关的路径和参数等。 2. 图像预处理:在进行文字识别之前,通常需要对图像进行预处理,包括图像读取和处理、图像去噪和增强、图像分割和归一化等操作。这些操作可以提高文字识别的准确率和效果。 3. 文字识别算法:文字识别主要有两种算法,一种是基于模板匹配的文字识别,通过事先构建模板库,然后匹配输入图像中的文字;另一种是基于OCR引擎的文字识别,通过OCR引擎对图像中的文字进行识别。根据实际情况选择合适的算法来进行文字识别。 4. 文字识别应用:文字识别可以应用于很多领域,如批量处理图片中的文本、提取实时摄像头中的文字、文字识别在自然语言处理中的应用等。根据不同的需求,选择合适的应用场景来使用文字识别技术。 总体来说,Python3在文字识别技术中的应用还有很大的发展空间。未来,随着深度学习和人工智能的不断发展,文字识别技术将会变得更加精准和高效。同时,Python3作为一门简洁易学的编程语言,将继续在文字识别中发挥重要作用。 本文所介绍的内容只是文字识别技术的一小部分,还有很多其他的知识和算法值得深入研究。希望本文能为读者提供一些参考和启发,并对文字识别技术的发展起到一定的推动作用。感谢大家的阅读!
corwn 最低0.47元/天 解锁专栏
送3个月
profit 百万级 高质量VIP文章无限畅学
profit 千万级 优质资源任意下载
profit C知道 免费提问 ( 生成式Al产品 )

相关推荐

张_伟_杰

人工智能专家
人工智能和大数据领域有超过10年的工作经验,拥有深厚的技术功底,曾先后就职于多家知名科技公司。职业生涯中,曾担任人工智能工程师和数据科学家,负责开发和优化各种人工智能和大数据应用。在人工智能算法和技术,包括机器学习、深度学习、自然语言处理等领域有一定的研究
专栏简介
本专栏主题为Python3文字识别转语音播报技术。专栏内容包括Python3文字识别的原理、应用、库的使用详解、算法分析与优化、中文文字识别技术、深度学习中的应用、计算机视觉中的应用、语音识别中的关联应用、智能交互系统建模、多媒体应用创新、增强现实应用、自动辨识发展、安防领域应用以及智能交通系统应用等方面。通过专栏,读者可以全面了解Python3文字识别技术的原理、应用,并学习如何使用Python3进行文字识别。无论是对于初学者还是对于有一定基础的开发者,本专栏都提供了深入讲解与实践经验分享,有助于读者在实际项目中灵活运用文字识别技术。
最低0.47元/天 解锁专栏
送3个月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )

最新推荐

揭秘MySQL数据库性能下降幕后真凶:提升数据库性能的10个秘诀

![揭秘MySQL数据库性能下降幕后真凶:提升数据库性能的10个秘诀](https://picx.zhimg.com/80/v2-e8d29a23f39e351b990f7494a9f0eade_1440w.webp?source=1def8aca) # 1. MySQL数据库性能下降的幕后真凶 MySQL数据库性能下降的原因多种多样,需要进行深入分析才能找出幕后真凶。常见的原因包括: - **硬件资源不足:**CPU、内存、存储等硬件资源不足会导致数据库响应速度变慢。 - **数据库设计不合理:**数据表结构、索引设计不当会影响查询效率。 - **SQL语句不优化:**复杂的SQL语句、

云计算架构设计与最佳实践:从单体到微服务,构建高可用、可扩展的云架构

![如何查看python的安装路径](https://img-blog.csdnimg.cn/3cab68c0d3cc4664850da8162a1796a3.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5pma5pma5pio5pma5ZCD5pma6aWt5b6I5pma552h6K-05pma,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. 云计算架构演进:从单体到微服务 云计算架构经历了从单体到微服务的演进过程。单体架构将所有应用程序组件打

Python在Linux下的安装路径在机器学习中的应用:为机器学习模型选择最佳路径

![Python在Linux下的安装路径在机器学习中的应用:为机器学习模型选择最佳路径](https://img-blog.csdnimg.cn/img_convert/5d743f1de4ce01bb709a0a51a7270331.png) # 1. Python在Linux下的安装路径 Python在Linux系统中的安装路径是一个至关重要的考虑因素,它会影响机器学习模型的性能和训练时间。在本章中,我们将深入探讨Python在Linux下的安装路径,分析其对机器学习模型的影响,并提供最佳实践指南。 # 2. Python在机器学习中的应用 ### 2.1 机器学习模型的类型和特性

【实战演练】数据聚类实践:使用K均值算法进行用户分群分析

![【实战演练】数据聚类实践:使用K均值算法进行用户分群分析](https://img-blog.csdnimg.cn/img_convert/225ff75da38e3b29b8fc485f7e92a819.png) # 1. 数据聚类概述** 数据聚类是一种无监督机器学习技术,它将数据点分组到具有相似特征的组中。聚类算法通过识别数据中的模式和相似性来工作,从而将数据点分配到不同的组(称为簇)。 聚类有许多应用,包括: - 用户分群分析:将用户划分为具有相似行为和特征的不同组。 - 市场细分:识别具有不同需求和偏好的客户群体。 - 异常检测:识别与其他数据点明显不同的数据点。 # 2

Python连接MySQL数据库:区块链技术的数据库影响,探索去中心化数据库的未来

![Python连接MySQL数据库:区块链技术的数据库影响,探索去中心化数据库的未来](http://img.tanlu.tech/20200321230156.png-Article) # 1. 区块链技术与数据库的交汇 区块链技术和数据库是两个截然不同的领域,但它们在数据管理和处理方面具有惊人的相似之处。区块链是一个分布式账本,记录交易并以安全且不可篡改的方式存储。数据库是组织和存储数据的结构化集合。 区块链和数据库的交汇点在于它们都涉及数据管理和处理。区块链提供了一个安全且透明的方式来记录和跟踪交易,而数据库提供了一个高效且可扩展的方式来存储和管理数据。这两种技术的结合可以为数据管

Python连接PostgreSQL机器学习与数据科学应用:解锁数据价值

![Python连接PostgreSQL机器学习与数据科学应用:解锁数据价值](https://img-blog.csdnimg.cn/5d397ed6aa864b7b9f88a5db2629a1d1.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAbnVpc3RfX05KVVBU,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. Python连接PostgreSQL简介** Python是一种广泛使用的编程语言,它提供了连接PostgreSQL数据库的

Python类方法与静态方法在金融科技中的应用:深入探究,提升金融服务效率

![python类方法和静态方法的区别](https://img-blog.csdnimg.cn/e176a6a219354a92bf65ed37ba4827a6.png) # 1. Python类方法与静态方法概述** ### 1.1 类方法与静态方法的概念和区别 在Python中,类方法和静态方法是两种特殊的方法类型,它们与传统的方法不同。类方法与类本身相关联,而静态方法与类或实例无关。 * **类方法:**类方法使用`@classmethod`装饰器,它允许访问类变量并修改类状态。类方法的第一个参数是`cls`,它代表类本身。 * **静态方法:**静态方法使用`@staticme

揭秘Django框架入门秘籍:从零构建Web应用程序

![python框架django入门](https://i0.hdslb.com/bfs/archive/ea121dab468e39a63cd0ccad696ab3ccacb0ec1c.png@960w_540h_1c.webp) # 1. Django框架简介 Django是一个开源的Python Web框架,用于快速、安全地构建可扩展的Web应用程序。它遵循MVC(模型-视图-控制器)架构,提供了一系列开箱即用的组件,简化了Web开发过程。Django的优势包括: - **快速开发:**Django提供了强大的工具和自动化功能,使开发人员能够快速构建Web应用程序。 - **可扩展性

Python enumerate函数在医疗保健中的妙用:遍历患者数据,轻松实现医疗分析

![Python enumerate函数在医疗保健中的妙用:遍历患者数据,轻松实现医疗分析](https://ucc.alicdn.com/pic/developer-ecology/hemuwg6sk5jho_cbbd32131b6443048941535fae6d4afa.png?x-oss-process=image/resize,s_500,m_lfit) # 1. Python enumerate函数概述** enumerate函数是一个内置的Python函数,用于遍历序列(如列表、元组或字符串)中的元素,同时返回一个包含元素索引和元素本身的元组。该函数对于需要同时访问序列中的索引

【进阶篇】数据透视表与交叉分析:Pandas中的PivotTable应用

![python数据分析与可视化合集](https://img-blog.csdnimg.cn/1934024a3045475e9a3b29546114c5bc.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBAU2hvd01lQUk=,size_20,color_FFFFFF,t_70,g_se,x_16) # 2.1 创建数据透视表 ```python import pandas as pd # 创建一个数据框 df = pd.DataFrame({ "name": ["Jo