Python PIL库使用指南
一、什么是PIL?PIL(Python Imaging Library)是Python中最常用的图像处理库,它提供了丰富的图像处理功能,如打开、保存、调整大小、裁剪、旋转、滤镜等。PIL已经被Pillow库所取代,Pillow是PIL的一个分支,提供了更多的功能和更好的支持。 二、安装Pillow1pip install Pillow 三、基本操作1. 打开和显示图像123456789101112from PIL import Image# 打开图像img = Image.open('image.jpg')# 显示图像img.show()# 查看图像信息print(f"图像大小:{img.size}")print(f"图像模式:{img.mode}")print(f"图像格式:{img.format}") 2. 保存图像12345678from PIL import Image# 打开图像img = Image.open('im...
CMake 案例实战:构建多文件计算项目
导言在掌握 CMake 基础用法后,本文将通过一个完整的多文件计算项目案例,深入讲解 CMake 在实际开发中的应用。该案例包含加减乘除四个运算模块,通过 CMake 实现自动化构建,同时覆盖源文件搜索、头文件路径配置、变量使用等核心技巧,帮助你将 CMake 知识落地到实际项目中。 一、项目整体概览1.1 项目功能该项目实现了整数的加减乘除基本运算,通过main.cpp中的test()函数调用各运算模块,最终在控制台输出计算结果。项目结构清晰,将不同运算逻辑拆分到独立的源文件和头文件中,符合模块化开发思想。 1.2 完整文件结构1234567891011calc_project/├── add.cpp # 加法运算实现├── add.h # 加法运算声明├── CMakeLists.txt # CMake配置文件├── divi.cpp # 除法运算实现├── divi.h # 除法运算声明├── main.cpp # 主程序(测试入口)├── mult.cpp # 乘法运算实现├── mult...
CMake 初步使用
CMake 初步使用CMake 是一个跨平台的构建系统生成工具,它可以根据简单的配置文件(CMakeLists.txt)生成不同平台的构建文件(如 Makefile、Visual Studio 项目文件等)。对于 C/C++ 项目,掌握 CMake 的基本使用能极大简化跨平台开发流程。 一、CMake 基本概念 CMakeLists.txt:CMake 的配置文件,描述项目的构建规则 构建目录:存放生成的构建文件和编译产物的目录,通常建议与源代码分离 生成器:CMake 支持的不同构建系统(如 Unix Makefiles、Visual Studio、Xcode 等) 目标(Target):CMake 中要构建的实体(可执行文件、库等) 二、安装 CMake Windows:从 CMake 官网 下载安装包,勾选 "Add CMake to the system PATH" Linux:通过包管理器安装 sudo apt install cmake(Debian/Ubuntu)或 sudo yum install cmake(C...
Python CSV模块使用指南
一、什么是CSV?CSV(Comma-Separated Values)是一种简单的文件格式,用于存储表格数据,如电子表格或数据库。CSV文件中的每行代表表格中的一行,每行中的值用逗号(或其他分隔符)分隔。 二、Python的CSV模块Python标准库中的csv模块提供了处理CSV文件的功能,它可以帮助你读取和写入CSV文件,处理各种CSV格式的变体。 三、读取CSV文件1. 基本读取123456import csvwith open('data.csv', 'r', encoding='utf-8') as f: reader = csv.reader(f) for row in reader: print(row) 2. 读取为字典123456import csvwith open('data.csv', 'r', encoding='utf-8') as f: reader = csv.DictReader(f) ...
C++核心语法整理
C++核心语法整理C与C++类与对象C++输入输出流友元与运算符重载关联式容器继承多态模板移动语义与资源管理C与C++ C++程序介绍 g++编译器安装 sudo apt install g++ 源文件名称 .cc .cpp C++程序模板设置 /home/st/.vim/plugged/prepare-code/snippet hello world程序分析 #include C++标准库中头文件 没有.h cin 标准输入流 默认输入设备 从键盘接收数据 cout 标准输出流 默认输出设备 屏幕 int main(int argc , char *argv[]){} 返回值为int argc 命令行参数的个数 argv 具体的命令行参数 vim中启动鼠标 编辑.vimrc文件 子主题 命名空间 命名空间是什么, 有什么作用? C++中的一种避免名字冲突的机制 主要作用区分同名实体 实体 变量、常量、函数、结构体、类、对象...
SAX vs. DOM:流式处理与树状模型
一、核心区别:内存快照 vs. 事件流先明确最本质的差异:DOM 解析器会为整个XML文档创建一个内存快照,构建一棵完整的节点树;而 SAX 解析器则像一个事件流处理器,逐行扫描文档并触发事件。这一区别决定了它们在内存占用、处理速度和编程模型上的根本不同,是XML处理技术中“空间换时间”与“时间换空间”的经典对决。 二、分场景深度解析1. DOM:将整个文档“拍”进内存DOM(Document Object Model)的核心思想是一次性加载整个XML文档,在内存中构建一个与文档层级结构完全对应的对象树。这就像给一座建筑拍下一张高清全景照片,所有细节(房间、门窗、楼层关系)都一览无余。 工作原理:解析器从XML文件的根元素开始,递归地读取每个节点,并在内存中创建相应的对象(如 Document, Element, Attr, Text)。这些对象通过父子、兄弟关系相互连接,形成一个完整的对象树。 实现特点: 随机访问:由于整个树都在内存中,你可以随时、随意地访问树中的任何一个节点,向前或向后遍历都极其方便。 易于编程:其API非常直观,符合人们对树形结构的认知,上手简单,代...
func(int) & func(int x)
一、核心区别:参数名的「存在意义」先明确最本质差异:**func(int){}**省略参数名,**func(int x){}**指定参数名x。这一区别在函数「声明」和「定义」场景中影响截然不同,且仅在 C/C++ 等少数语言中合法(Python、Java 等需强制指定参数名)。 二、分场景深度解析1. 函数声明阶段:几乎无差异在头文件或函数原型声明中,两者作用完全一致 ——仅告知编译器「函数接收一个 int 类型参数」,参数名不影响函数签名。 示例: 123// 以下两种声明等效,编译器均识别为「接收int、返回void」的函数void func(int); // 省略参数名(常用)void func(int x); // 带参数名(可选,仅作注释提示) 正如中关村在线问答指出的:声明只需说明参数类型,参数名「没什么用」。编译器处理时,会忽略声明中的参数名,仅记录函数名和参数类型序列。 2. 函数定义阶段:可用性天差地别函数定义(实现)时,参数名的有无直接决定「能否在函数体内使用该参数」: func(int x){}:可正常操作参数 x是参数的...
拒绝死记硬背!用 C++ 的底层逻辑,彻底搞懂 Python 的“魔术方法”
一、引言:打破“魔法”的迷信初学者看到 __init__、__str__ 这种双下划线方法就头大,只能死记硬背。但对于C++程序员来说,这些其实就是编译器在特定时刻自动调用的“钩子函数”。 二、核心类比 Python 的 obj + obj 对应 C++ 的 operator+ 重载 Python 的 str(obj) 对应 C++ 的 operator std::string() 或 toString() 虚函数 Python 的 cls 对应 C++ 的 static 类作用域 三、变身术:类型转换协议 (str vs int)1. __str__ (人类视图) C++ 类比:相当于 C++ 中重载 std::ostream& operator<<(std::ostream&, const T&) 触发时机:当你执行 print(obj) 或 str(obj) 时 用途:返回一个人类可读的字符串 2. __repr__ (机器视图) C++ 类比:相当于调试器中显示对象的逻辑 触发时机:当你在交互式终端中直接输入对象名并回车时 用途:返...
STL标准模板库内容整理
STL标准模板库(重点):C++工具(类模板与函数模板) STL标准模板库 本质上就是数据结构和算法 C语言标准库未直接提供 C++标准库直接提供 定义:高效C程序库,含基本数据结构和算法,属C标准库,采用泛型编程 泛型编程:抽象数据类型,用泛型代替具体类型,编写通用代码 六大组件 容器(重要):存储数据(数据结构) 序列式容器:vector、list、deque等 关联式容器:set、map等 无序关联式容器:unordered_set、unordered_map等 迭代器:访问容器元素,泛型指针(例:vector::iterator) 算法:操作容器元素的普通函数(例:std::sort) 适配器:适配作用 容器适配器:stack、queue、priority_queue 迭代器适配器 函数适配器:bind、bind1st、bind2nd、function等 函数对象:实现定制化操作 空间配置器:管理内存(使用、原理、源码) 六大组件 容器 作用:存放数据 1、序列式容器 模型理解 array 静态数组,大小固定的数...
C++ 实现高效单词转换工具
一、需求与设计分析1.1 核心需求根据 C++ Primer 11.3.6 练习要求,工具需满足以下功能: 规则加载:从map.txt读取替换规则(每行格式:待替换单词 替换后的短语) 文本处理:读取file.txt中的待转换文本,将匹配规则的单词替换为对应短语 结果输出:将替换后的文本写入output.txt 灵活性:支持通过命令行参数自定义规则文件、输入文件和输出文件路径 鲁棒性:处理文件打开失败、格式错误等异常情况 1.2 示例输入输出 规则文件(map.txt):定义替换映射 12345678brb be right backk okay?y whyr areu youpic picturethk thanks!l8r later 待转换文本(file.txt):包含缩写词的原始文本 123where r uy dont u send me a pick thk l8r 预期输出(output.txt):替换后的标准文本 123where are youwhy dont you send me a pictureokay? thanks! later ...
Python装饰器本质深度解析
一、装饰器的本质装饰器本质上就是高阶函数加语法糖。你想啊,装饰器做的事情就是:接收一个函数,包一层,返回一个新的函数。这不就是典型的高阶函数吗? @decorator 等价于 func = decorator(func),就是把原函数传给装饰器,装饰器决定什么时候调用它、传什么参数进去,然后再返回一个升级后的函数。 二、装饰器的基本结构让我们来看一个最简单的装饰器: 1234567891011121314def simple_decorator(func): def wrapper(*args, **kwargs): print("Before function call") result = func(*args, **kwargs) print("After function call") return result return wrapper@simple_decoratordef say_hello(name): print(f"Hello, ...
《STL 源码剖析》读书笔记
导言作为具备一定工程实践经验的中级软件工程师,在日常软件开发工作流中,C++ 标准模板库(Standard Template Library,STL)的容器与算法体系已成为不可或缺的编程工具。vector 的动态内存管理机制、map 的有序键值对存储特性,以及 sort 算法的高效执行范式,这些看似常规的编程操作,实则蕴含着深邃的计算机科学设计思想。通过研读侯捷所著《STL 源码剖析》,得以系统性解构 STL 的底层实现逻辑,深刻体会到 "知其然更知其所以然" 在软件工程领域的重要价值。 一、数据结构:从应用层到实现层的认知跃迁在数据结构层面,STL 核心容器的底层实现机制在书中得到细致解析。以 vector 容器为例,其动态数组特性不仅体现在可扩展的存储容量上,更在于其内存管理策略的精妙设计。当容器容量不足时,vector 采用指数级扩容策略(通常为原容量的 2 倍或 1.5 倍,依具体实现而定),通过重新分配内存空间、元素迁移及旧内存释放的流程,在空间复杂度与时间复杂度之间实现了高效平衡。这种 "以空间换时间" 的策略,有效规避了频繁内...
Python正则表达式re模块核心功能详解
在Python中,处理正则表达式的标准库是re。你可以把它想象成一把文本处理的“瑞士军刀”,专门用来在海量文本中查找、提取、替换或验证特定格式的字符串。 一、核心工具箱:5个最常用的方法在使用前,记得先导入模块:import re 方法 作用 形象比喻 返回值 re.match() 从开头匹配 “必须从门口进入” 匹配成功返回对象,失败返回None re.search() 扫描全文找第一个 “在屋里找一遍,找到就停” 匹配成功返回对象,失败返回None re.findall() 找到所有匹配项 “把所有符合条件的都抓出来” 列表 ['a', 'b', ...] re.sub() 替换文本 “把这里的A换成B” 替换后的新字符串 re.split() 按规则分割 “按这个符号切开” 分割后的列表 二、代码实战:一看就懂1. 查找与提取(search vs findall)如果你想提取文本中的手机号或数字: 123456789101112import retext = "我的手机号是 13800138000,备...
CS50 课程核心:计算机思维的系统化构建与实践
一、计算思维的本质与形式化表达1.1 信息处理的抽象模型与问题抽象计算机科学核心是信息符号操纵体系,从图灵机到现代系统,均为 "输入 - 处理 - 输出" 的具象实现。计算思维通过建立现实与符号系统映射实现问题可计算,这种抽象过程包含三个关键步骤:问题特征提取、符号系统选择与映射规则定义。这种抽象能力,正是计算机解决问题的前提,体现了从具体到抽象的认知跃迁,也印证了问题解决需建立与抽象模型间映射关系的理论。 1.2 指令序列的执行逻辑与计算思维维度计算过程的本质是按确定规则执行指令序列,这种确定性是可计算性的基础。指令通过顺序、分支和循环三种基本结构,构成复杂计算的控制流,体现了计算思维将问题拆解为可计算步骤的核心逻辑。 指令执行模型展现过程分解思维:复杂计算可拆分为有序的基本操作,执行路径明确,结果可预测。这种分解基于对问题逻辑的深入理解,需借助可计算性理论判断问题是否可解,并设计有限步骤的算法,确保在合理时间复杂度内得出确定解。 二、编程的思维框架2.1 程序结构的模块化组织与抽象层次驾驭C 语言以函数实现模块化,将复杂程序分解为相对独立的功能模块,通过接...
Python正则表达式re.IGNORECASE使用指南
一、什么是re.IGNORECASE?re.IGNORECASE是Python re模块中的一个标志(Flag),用于在执行正则表达式匹配时忽略字母的大小写。它的简写形式是re.I。 二、为什么使用它?默认情况下,正则表达式是区分大小写的。例如,模式python只能匹配小写的"python",无法匹配"Python"或"PYTHON"。使用re.IGNORECASE可以解决这个问题,让匹配过程对大小写不敏感,这在处理用户输入、日志分析或关键词搜索时非常实用。 三、如何使用?1. 在函数中直接使用123456789101112import retext = "The quick Brown fox jumps over the lazy dog."pattern = "brown"# 不加re.IGNORECASE,匹配失败result1 = re.search(pattern, text)print(result1) # 输出: None# 加上re.IGNORECASE,成功匹...
迭代器与迭代适配器
引言:迭代器的核心价值在 C++ 标准模板库 (STL) 中,迭代器扮演着 "胶水" 的角色,它连接了容器与算法,使算法能够独立于具体容器类型工作。这种抽象机制带来了极大的灵活性 —— 同一个排序算法可以作用于向量 (vector)、链表 (list) 或数组 (array),只需它们提供兼容的迭代器。 迭代适配器则是在基础迭代器之上的增强,通过包装现有迭代器,提供反向遍历、插入操作等特殊行为,进一步扩展了迭代器的能力。本文将系统解析迭代器的分类、实现原理及迭代适配器的应用场景。 一、迭代器基础:概念与分类1.1 迭代器的本质迭代器本质上是一种泛化的指针,它重载了*、->、++等运算符,使开发者能够以统一的方式访问容器中的元素,而不必关心容器的内部实现细节。 1234567891011121314151617181920212223#include <vector>#include <list>#include <iostream>// 通用打印函数,适用于任何提供输入迭代器的容器template<typenam...
函数对象
一、函数对象的本质函数对象(也称为仿函数,Functor)是*重载了函数调用运算符***operator()**的类或结构体的实例。这种特殊的设计使它能够像普通函数一样被调用,同时又具备对象的所有特性。 12345678910111213141516// 一个简单的函数对象类struct Add { // 重载函数调用运算符 int operator()(int a, int b) const { return a + b; }};// 使用方式int main() { Add add; int result = add(3, 5); // 像函数一样调用对象 // 也可以直接使用临时对象 int result2 = Add()(10, 20); return 0;} 从本质上讲,函数对象是一个带行为的对象,而普通函数是一段可执行代码。这种本质差异决定了它们在功能和适用场景上的不同。 二、函数对象与普通函数的核心区别2.1 状态管理能力这是两者最根本的区别...
Python模块与包深度解析
一、什么是模块?在Python中,模块是一个包含Python定义和语句的文件。文件名就是模块名加上.py后缀。例如,一个名为my_module.py的文件就是一个名为my_module的模块。 二、导入模块1. 基本导入1234import my_module# 使用模块中的函数my_module.say_hello() 2. 导入特定函数1234from my_module import say_hello# 直接使用函数say_hello() 3. 导入所有函数1234from my_module import *# 直接使用模块中的所有函数say_hello() 4. 导入并别名12345678910import my_module as mm# 使用别名访问模块mm.say_hello()# 或者from my_module import say_hello as sh# 使用别名访问函数sh() 三、模块的搜索路径当你导入一个模块时,Python会按照以下顺序搜索模块: 当前目录 PYTHONPATH环境变量中指定的目录 标准库目录 任何.pth文件中指定的目...
Python文件操作深度解析
一、文件操作的基本概念在Python中,文件操作是一个非常基础但重要的功能。Python提供了多种方式来处理文件,包括打开、读取、写入、关闭等操作。 二、文件的打开与关闭1. 基本打开方式12345# 打开文件f = open('file.txt', 'r')# 关闭文件f.close() 2. 使用with语句为了避免忘记关闭文件,我们可以使用with语句,它会自动处理文件的关闭: 1234with open('file.txt', 'r') as f: # 处理文件 pass# 文件会自动关闭 三、文件的读取1. 读取整个文件123with open('file.txt', 'r') as f: content = f.read() print(content) 2. 逐行读取123with open('file.txt', 'r') as f: for line in f: ...
C++ Lambda 表达式
导言在现代 C++ 开发中,lambda 表达式(匿名函数)已经成为编写简洁高效代码的重要工具。尤其在配合 STL 算法(如for_each)时,lambda 表达式能够消除编写命名函数或函数对象的额外开销,使代码更加紧凑直观。 一、Lambda 表达式的基本语法lambda 表达式的完整语法结构如下: 123[capture](parameters) mutable noexcept -> return_type { // 函数体} 各组成部分的含义: [capture]:捕获列表,定义 lambda 表达式可以访问的外部变量 (parameters):参数列表,与普通函数的参数列表类似 mutable:可选修饰符,允许修改按值捕获的变量 noexcept:可选修饰符,指定函数不会抛出异常 -> return_type:返回类型,当函数体只有 return 语句时可省略 {}:函数体,包含具体的执行逻辑 1.1 最简单的 Lambda 表达式最简化的 lambda 表达式可以省略参数列表、返回类型和修饰符,仅保留捕...
模板实现堆排序算法
导言堆排序是一种基于二叉堆数据结构的高效排序算法,具有 O (n log n) 的时间复杂度和原地排序的特性。使用模板实现堆排序可以使其灵活适用于各种数据类型,并支持自定义比较规则。 一、堆排序算法原理堆排序主要分为两个阶段: 建堆阶段:将无序数组构建成一个二叉堆(最大堆或最小堆) 排序阶段:反复提取堆顶元素(最大值或最小值),并调整剩余元素维持堆特性 二叉堆是一种完全二叉树,对于最大堆,每个父节点的值大于或等于其子节点的值;对于最小堆,每个父节点的值小于或等于其子节点的值。 二、模板类实现下面是完整的HeapSort模板类实现,基于提供的框架结构: 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788#include <vector>#include <functional>...
unordered_map存放自定义类具体实现
一、引言上一篇文章介绍了unordered_map存放自定义类型的六种方法的理论框架,本文将通过完整可运行的代码示例,详细展示每种方法的具体实现细节。这六种方法是通过 2 种哈希实现方式与 3 种相等性比较方式组合而成,每种组合都有其独特的实现要点。 二、基础准备首先定义基础的Point类和测试函数,作为六种方法的共同基础: 12345678910111213141516171819202122232425262728293031323334353637383940#include <iostream>#include <unordered_map>#include <string>#include <functional>// 自定义点类型class Point {private: int x; int y;public: Point(int x_ = 0, int y_ = 0) : x(x_), y(y_) {} int getX() const { re...
C++ 模板实现快速排序算法
导言快速排序是一种高效的分治排序算法,平均时间复杂度为 O (n log n)。使用 C++ 模板实现快速排序可以使其适用于各种数据类型,配合比较器还能灵活调整排序规则。 一、快速排序算法原理快速排序的核心思想是: 选择一个元素作为 "基准"(pivot) 将数组分区,所有比基准值小的元素移到基准前面,比基准值大的元素移到基准后面 递归地对前后两个子数组进行排序 这种分治策略使快速排序成为实际应用中最快的排序算法之一。 二、模板类实现下面是完整的MyQsort模板类实现,支持任意可比较的数据类型和自定义比较规则: 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687#include <vector>#include <functional>#include &...
Python海象运算符深度解析
一、什么是海象运算符?海象运算符(Walrus Operator)是Python 3.8引入的新特性,它的语法是:=,读作“赋值表达式”。这个运算符的名字来源于它的外观,:= 看起来像一只眼睛和两颗长牙的海象。 二、与C++=运算符的区别与C++中=运算符不同,Python中的:=运算符在赋值后返回结果,而不是赋值前返回结果: C++:=运算符在赋值前返回结果,而不是赋值后返回结果 Python::=运算符在赋值后返回结果,而不是赋值前返回结果 三、海象运算符的使用场景1. 在if语句中12345678# 传统写法user_input = input("请输入:")if user_input: print(f"你输入了:{user_input}")# 使用海象运算符if (user_input := input("请输入:")): print(f"你输入了:{user_input}") 2. 在while循环中123456789# 传...
unordered_map 存放自定义类型的六种方法
引言std::unordered_map是 C++ 标准库中提供的无序关联容器,与std::map不同,它通过哈希表实现,因此需要两个关键组件:哈希函数(用于计算键的哈希值)和相等性比较函数(用于判断两个键是否相等)。当使用自定义类型作为unordered_map的键时,我们需要显式提供这两种组件。 一、核心概念std::unordered_map的模板定义如下: 1234567template< class Key, class T, class Hash = std::hash<Key>, // 哈希函数类型 class KeyEqual = std::equal_to<Key>, // 相等性比较类型 class Allocator = std::allocator<std::pair<const Key, T>>> class unordered_map; Hash类型必须满足Hash概念:Hash对象的operator()接受const Key&参数,返回s...

