文本匹配.grep与Select-String用法对比

news/2024/7/20 18:38:30/文章来源:https://blog.csdn.net/qq_28550263/article/details/139253970
Linux Shell与PowerShell上匹配字符串
grep与Select-String用法对比

- 文章信息 - Author: 李俊才 (jcLee95)
Visit me at CSDN: https://jclee95.blog.csdn.net
My WebSitehttp://thispage.tech/
Email: 291148484@163.com.
Shenzhen China
Address of this article:https://blog.csdn.net/qq_28550263/article/details/139253970
HuaWei:https://bbs.huaweicloud.com/blogs/428150

【介绍】:grep用于在 Linux 和其他类 Unix 系统中搜索文本。Select-String 是 PowerShell 中用于搜索和匹配文本的cmdlet。它提供了类似于 grep 的功能。现在将两者放在一起做个总结。

在这里插入图片描述


1. 用法简介

在文本搜索方面,Linux 和 PowerShell 提供了各自强大的工具。grep 是 Linux 中用于搜索文本的命令行工具,而 Select-String 是 PowerShell 中用于搜索文本的 cmdlet,功能类似于 grep

1.1 grep 命令

grep(Global Regular Expression Print)用于在 Linux 和其他类 Unix 系统中搜索文本。它可以在一个或多个文件中查找包含指定模式的行,并将匹配的行输出到标准输出。grep 支持正则表达式,提供了多种选项来控制搜索行为和输出格式。

grep 命令的基本格式如下:

grep [OPTIONS] PATTERN [FILE...]

其中,OPTIONS 表示可选的命令行选项,PATTERN 表示要搜索的模式(可以是普通字符串或正则表达式),FILE 表示要搜索的一个或多个文件。如果未指定文件,grep 将从标准输入读取文本。

1.2 Select-String 命令

Select-StringPowerShell 中用于搜索和匹配文本的 cmdlet。它提供了类似于 grep 的功能,可以在文件、字符串或管道输入中查找指定的模式。Select-String 支持正则表达式和通配符,并提供了各种参数来控制搜索行为和输出格式。

Select-String 命令的基本格式如下:

Select-String [-Path] <string[]> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]Select-String -InputObject <psobject> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

其中:

  • -Pattern 参数指定要搜索的模式(可以是普通字符串或正则表达式);
  • -Path 参数指定要搜索的一个或多个文件。

Select-String 还提供了其他参数,如 -SimpleMatch(简单字符串匹配)、-CaseSensitive(区分大小写)、-Quiet(仅返回布尔值)等,用于控制搜索行为和输出格式。

2. grep详细用法与示例

2.1 基本用法

Linux上,grep命令用于在每个文件中搜索指定的模式。其基本使用格式为:

grep [选项]... 模式 [文件]...

grep命令会在指定的文件中查找匹配的模式,并输出包含该模式的行。如果未指定文件,grep会从标准输入读取数据。

例如,下面的命令在menu.hmain.c文件中搜索不区分大小写的字符串“hello world”:

grep -i 'hello world' menu.h main.c

在这个例子中:

  • -i选项表示忽略大小写,因此Hello, HELLO,或hello都能匹配模式hello world
  • 'hello world'是要搜索的模式。
  • menu.hmain.c是要搜索的文件。

这条命令会输出包含“hello world”的所有行,无论这些行中的“hello world”是大写、小写还是混合大小写。

2.2 模式

其中,模式可以包含多个由换行符分隔的模式。模式选择及其解释如下:

  -E, --extended-regexp     模式为扩展正则表达式-F, --fixed-strings       模式为字符串-G, --basic-regexp        模式为基本正则表达式-P, --perl-regexp         模式为Perl正则表达式-e, --regexp=模式         使用指定的模式进行匹配-f, --file=文件           从文件中获取模式-i, --ignore-case         忽略模式和数据中的大小写区别--no-ignore-case      不忽略大小写区别(默认)-w, --word-regexp         仅匹配整个单词-x, --line-regexp         仅匹配整个行-z, --null-data           数据行以0字节结束,而不是换行符
杂项:-s, --no-messages         抑制错误消息-v, --invert-match        选择不匹配的行-V, --version             显示版本信息并退出--help                显示此帮助文本并退出

【注】:在接下来的示例中,输出结果中的颜色是由 grep 命令自动添加的,用于突出显示匹配的部分。这是 grep 的一个特性,称为 “颜色输出”。
当在终端中运行 grep 命令时,它会自动检测是否支持颜色输出,并相应地着色。
可以参考2.4.3小节。

2.2.1 例:使用扩展正则表达式

使用-E选项,可以使用扩展正则表达式。

例如,以下命令会在file.txt中搜索匹配任意一个字母后跟一个数字的字符串:

grep -E '[a-zA-Z][0-9]' file.txt

再如,搜索包含一个到三个’a’字符的模式。

echo "aaa abbb aaaa" | grep -E 'a{1,3}'

输出为:
在这里插入图片描述

在输出结果 “aaa abbb aaaa” 中:

  • 第一部分 “aaa” 匹配正则表达式,因为它包含连续的三个 ‘a’ 字符,所以显示为红色;

  • 第二部分 “abbb” 不匹配正则表达式,因为 ‘a’ 后面没有连续的 ‘a’ 字符,所以显示为白色。

  • 第三部分 “aaaa” 匹配正则表达式,因为它包含连续的四个 ‘a’ 字符,前三个 ‘a’ 匹配,所以前三个 ‘a’ 显示为红色,剩下的 ‘a’ 显示为白色。

2.2.2 例:将模式视为固定字符串

搜索包含确切字符串’a*b’的行。

echo "a*b a b" | grep -F 'a*b'

结果为:
在这里插入图片描述

2.2.3 例:从文件中获取模式

echo "hello" > patterns.txt
echo "world" >> patterns.txt
echo "hello world" | grep -f patterns.txt

2.2.4 例:忽略大小写

echo "Hello WORLD" | grep -i 'hello'

结果为:

在这里插入图片描述

2.2.5 例: 选择不匹配的行

echo "hello world
hello universe
goodbye world
hello hello" | grep -v 'hello'

在这个例子中,我们使用 echo 命令生成了一个包含多行文本的字符串,每行文本之间用换行符 \n 分隔。然后,我们使用管道将这个多行文本传递给 grep -v 'hello' 命令。

-v 选项表示 “反转匹配”,即选择不包含指定模式的行。在这里,grep -v 'hello' 会输出所有不包含 “hello” 的行。

输出结果为:

goodbye world

2.2.6 例: 匹配整行

-x 选项用于匹配整行,即只有当整行完全匹配指定的模式时才会被选中。例如:

echo "hello
hello world
world
hello hello" | grep -x 'hello'

输出结果为:

hello

在这个例子中,我们使用 echo 命令生成了一个包含多行文本的字符串,每行文本之间用换行符 \n 分隔。然后,我们使用管道将这个多行文本传递给 grep -x 'hello' 命令。

-x 选项表示 “匹配整行”,即只有当一行文本完全匹配指定的模式时才会被选中。在这里,grep -x 'hello' 会输出完全匹配 “hello” 的行。

其中,只有第 1 行完全匹配 “hello”,所以被选中并输出。其他行虽然包含 “hello”,但并不是完全匹配,所以被过滤掉了。

2.3 输出控制

grep命令中也可以通过下面的选项对输出内容进行控制:

  -m, --max-count=NUM       在选择NUM行后停止-b, --byte-offset         打印输出行的字节偏移量-n, --line-number         打印输出行的行号--line-buffered       在每行后刷新输出-H, --with-filename       打印输出行的文件名-h, --no-filename         输出时不显示文件名前缀--label=LABEL         使用LABEL作为标准输入文件名前缀-o, --only-matching       仅显示匹配的非空部分-q, --quiet, --silent     抑制所有正常输出--binary-files=TYPE   假定二进制文件为TYPE;TYPE可以是'binary'(二进制)、'text'(文本)或'without-match'(无匹配)-a, --text                等同于--binary-files=text-I                        等同于--binary-files=without-match-d, --directories=ACTION  如何处理目录;ACTION可以是'read'(读取)、'recurse'(递归)或'skip'(跳过)-D, --devices=ACTION      如何处理设备、FIFO和套接字;ACTION可以是'read'(读取)或'skip'(跳过)-r, --recursive           等同于--directories=recurse-R, --dereference-recursive  同样,但跟随所有符号链接--include=GLOB        仅搜索匹配GLOB(文件模式)的文件--exclude=GLOB        跳过匹配GLOB的文件--exclude-from=FILE   跳过匹配FILE中的任何文件模式的文件--exclude-dir=GLOB    跳过匹配GLOB的目录-L, --files-without-match  仅打印没有选中行的文件名-l, --files-with-matches  仅打印有选中行的文件名-c, --count               每个文件仅打印选中行的计数-T, --initial-tab         对齐制表符(如有需要)-Z, --null                在文件名后打印0字节

2.3.1 例: 限制输出行数

seq 10 | grep -m 3 -E '[0-9]'

输出结果为:

1
2
3

在这个例子中,我们使用seq命令生成1到10的整数序列,然后通过管道传递给grep -m 3 -E '[0-9]'命令。

-m 3选项表示最多输出匹配的前3行. -E '[0-9]'使用正则表达式匹配所有包含数字的行。

2.3.2 例: 显示匹配内容的字节偏移

echo "hello world" | grep -b 'world'

输出结果为:

hello world

在这里插入图片描述

-b选项会在输出的每一行前面显示该行在原始输入中的字节偏移量。在这个例子中,"world"在输入字符串中的起始字节位置为6。

2.3.3 例: 显示行号

seq 10 | grep -n -E '[24680]$' 

-n选项会在输出的每一行前面显示该行在原始输入中的行号. 在这个例子中,我们匹配所有以偶数结尾的行。输出结果为:

2:2
4:4
6:6
8:8
10:10

在这里插入图片描述

2.4 上下文控制

上下文控制是指在输出匹配行的同时,也输出匹配行前后的一些行作为上下文,以便更好地理解匹配行在原始文本中的位置和含义。grep提供了一些选项来控制输出的上下文行数和格式。

  -B, --before-context=NUM  打印匹配前NUM行的上下文-A, --after-context=NUM   打印匹配后NUM行的上下文-C, --context=NUM         打印匹配前后各NUM行的上下文-NUM                      等同于--context=NUM--group-separator=SEP  在带有上下文的匹配行之间打印分隔符SEP--no-group-separator  不打印带有上下文的匹配行的分隔符--color[=WHEN],--colour[=WHEN]       使用标记突出显示匹配的字符串;WHEN可以是'always'(总是)、'never'(从不)或'auto'(自动)-U, --binary              不去除行尾的CR字符(MSDOS/Windows)

2.4.1 例: 输出匹配行前后的行作为上下文

seq 10 | grep -A 2 -B 2 '5'
  • -A 2选项表示输出匹配行后的2行作为上下文;
  • -B 2选项表示输出匹配行前的2行作为上下文;
    因此,这个命令会输出匹配行'5'以及它前后各2行。输出结果为:
3
4
5
6
7

在这里插入图片描述

2.4.2 例: 使用-C选项控制上下文行数

seq 10 | grep -C 1 '5'

-C 1选项等同于-A 1 -B 1,表示输出匹配行前后各1行作为上下文。出结果为:

4
5
6

在这里插入图片描述

2.4.3 例: 使用–color选项高亮匹配的字符串

--color=always选项会使用标记突出显示匹配的字符串,以便更容易识别匹配的位置。例如:

echo "Hello World" | grep --color=always 'World'

你可以尝试在终端中运行这个命令,看看’World’是否被高亮显示:

在这里插入图片描述

3. Select-String详细用法与示例

Select-String 是 PowerShell 中用于搜索和匹配文本的cmdlet。它提供了类似于 grep 的功能,可以在文件、字符串或管道输入中查找指定的模式。Select-String 支持正则表达式和通配符,并提供了各种参数来控制搜索行为和输出格式。

3.1 格式与参数

Select-String的基本格式如下:

Select-String [-Path] <string[]> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]Select-String -InputObject <psobject> [-Pattern] <string[]> [-AllMatches] [-CaseSensitive] [-Context <Int32[]>] [-Encoding <string>] [-Exclude <string[]>] [-Include <string[]>] [-List] [-NotMatch] [-Quiet] [-SimpleMatch] [<CommonParameters>]

3.2 用法示例

3.2.1 例: 在文件中搜索模式

Select-String -Pattern 'hello' -Path 'file.txt'

file.txt 文件中搜索包含 “hello” 的行。

3.2.2 例: 在文件中搜索模式

"hello world", "hello universe", "goodbye world" | Select-String -Pattern 'hello'

在给定的字符串数组中搜索包含 “hello” 的行。输出结果为:
在这里插入图片描述

3.2.3 例: 区分大小写

通过 -CaseSensitive 选项可以指定是否区分大小写。默认情况下,Select-String 不区分大小写,这意味着它会匹配模式的任何大小写组合。使用 -CaseSensitive 选项可以强制 Select-String 进行区分大小写的匹配。

"Hello world", "hello universe" | Select-String -Pattern 'hello' -CaseSensitive

在这里插入图片描述

3.2.4 例: 简单字符串匹配

"hello*world", "hello world" | Select-String -Pattern 'hello*world' -SimpleMatch

3.2.5 例: 简单字符串匹配

通过 -SimpleMatch 选项可以指定 Select-String 进行简单字符串匹配,而不是使用正则表达式。默认情况下,Select-String 会将模式解释为正则表达式。如果你希望进行简单的字符串匹配,可以使用 -SimpleMatch 选项。例如:

"hello*world", "hello world" | Select-String -Pattern 'hello*world' -SimpleMatch

输出结果为:

hello*world

在这个例子中,我们有一个包含两行文本的字符串数组:

  1. “hello*world”

  2. “hello world”

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern 'hello*world'-SimpleMatch 选项。

  • -Pattern 'hello*world' 指定要搜索的模式是 “hello*world”。

  • -SimpleMatch 选项指示 Select-String 进行简单字符串匹配,而不是将模式解释为正则表达式。

由于 -SimpleMatch 选项的作用,Select-String 会将模式 “helloworld" 作为一个普通字符串进行匹配。因此,只有第一行 "helloworld” 会被匹配并输出,因为它完全包含了字符串 “hello*world”。第二行 “hello world” 不会被匹配,因为它不包含星号 *

3.2.6 例: 显示匹配的上下文行

通过 -Context 选项可以指定在输出中显示匹配行的前后上下文行。这在需要查看匹配行周围的内容时非常有用。

"line1", "line2 hello", "line3", "line4 hello", "line5" | Select-String -Pattern 'hello' -Context 1,1

输出结果为:

  line1
> line2 helloline3
> line4 helloline5

在这里插入图片描述

在这个例子中,我们有一个包含多行文本的字符串数组:

  1. “line1”
  2. “line2 hello”
  3. “line3”
  4. “line4 hello”
  5. “line5”

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern ‘hello’ 和 -Context 1,1 选项。

-Pattern ‘hello’ 指定要搜索的模式是 “hello”。

-Context 1,1 选项指示 Select-String 显示每个匹配行的前一行和后一行。

由于 -Context 1,1 选项的作用,Select-String 会输出包含 “hello” 的行以及每个匹配行的前一行和后一行。

3.2.7 例: 搜索多个模式

通过 -Pattern 选项可以指定多个模式进行搜索。Select-String 会匹配任意一个指定的模式。

"hello world", "goodbye world" | Select-String -Pattern 'hello', 'goodbye'

搜索结果为:

hello world
goodbye world

在这里插入图片描述

在这个例子中,我们有一个包含两行文本的字符串数组: "hello world"和 “goodbye world”。

我们使用管道将这个字符串数组传递给 Select-String 命令,并指定 -Pattern 'hello', 'goodbye' 选项。

  • -Pattern 'hello', 'goodbye' 指定要搜索的模式是 “hello” 或 “goodbye”。

由于 -Pattern 选项的作用,Select-String 会输出包含 “hello” 或 “goodbye” 的行。

3.2.8 例: 只返回第一个匹配项

通过 -List 选项可以指定 Select-String 只返回每个输入中的第一个匹配项。这在你只关心第一个匹配结果时非常有用。

假设我们有两个文件 file1.txtfile2.txt,它们的内容如下:

file1.txt:

hello world
hello universe

file2.txt:

goodbye world
hello again

我们可以使用以下命令来搜索这两个文件,并只返回每个文件中的第一个匹配项:

Select-String -Pattern 'hello' -Path 'file1.txt', 'file2.txt' -List

输出结果为:

file1.txt:1:hello world
file2.txt:2:hello again

在这里插入图片描述

在这个例子中,Select-String 搜索 file1.txtfile2.txt 中包含 “hello” 的行,并使用 -List 选项只返回每个文件中的第一个匹配项。

3.2.9 例: 在指定编码的文件中搜索

Select-String -Pattern 'hello' -Path 'file.txt' -Encoding UTF8

在这个例子中,我们在名为 file.txt 的文件中搜索包含 “hello” 的行,并指定文件的编码为 UTF8。

  • -Pattern 'hello' 指定要搜索的模式是 “hello”。

  • -Path 'file.txt' 指定要搜索的文件是 file.txt。

  • -Encoding UTF8 选项指示 Select-String 使用 UTF8 编码来读取文件。

假设 file.txt 的内容如下:

hello world
goodbye world

运行上述命令的输出结果为:

file.txt:1:hello world

在这里插入图片描述

这个例子展示了如何使用 -Encoding 选项来在指定编码的文件中搜索。在处理不同编码的文件时,这可以确保 Select-String 正确读取文件内容并进行搜索。

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

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

平衡二叉树的构建(理论,部分函数代码)

平衡二叉树是二叉排序树的一种特殊情况&#xff0c;平衡二叉树的出现是为了在最坏情况下的时间复杂度仍然是对数级别O(logn)&#xff0c;从而保证了高效的搜索、插入和删除操作。 举个例子&#xff0c;如果有一个数组是&#xff1a;1&#xff0c;2&#xff0c;3。如果只简单的…

汇编原理(三)编程

源程序&#xff1a; 汇编指令&#xff1a;有对应的机器码与其对应 伪指令&#xff1a;无对应的机器码&#xff0c;是由编译器来执行的指令&#xff0c;编译器根据伪指令来进行相关的编译工作。 ex1:XXX segment、XXX ends这两个是一对成对使用的伪指令&#xff0c;且必须会被用…

【Go专家编程——内存管理——逃逸分析】

逃逸分析 逃逸分析&#xff08;Escape Analysis&#xff09;是指由编译器决定内存分配的位置&#xff0c;不需要程序员决定。 在函数中申请一个新的对象 如果分配在栈上&#xff0c;则函数执行结束后可自动将内存回收如果分配在堆上&#xff0c;则函数执行结束后可交给GC&…

FLUKE福禄克DSX-5000或者DSX-8000如何做外部串扰测试之实践篇

近期&#xff0c;有很多朋友问如何使用DSX5000或者DSX8000测外部串扰&#xff1f; 外部串扰测试在判定外部线缆是否对网络传输造成影响的重要一环。 直接上干货&#xff0c;测试步骤如下&#xff1a; 第一步:对主机和副机进行基准设置&#xff0c;保持同步!官方是建议每24小时…

【机器学习】探究DQN通过训练来解决AI序列决策问题

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN …

EpicDesigner编辑器的源码修改和扩展“数据库”进行数据库字段设置

项目介绍&#xff1a; EpicDesigner是一个功能强大、开箱即用的拖拽式低代码设计器。它基于 Vue3 开发&#xff0c;兼容多套 UI 组件库&#xff0c;除了基础的页面设计功能&#xff0c;EDesigner 还提供了强大的扩展功能&#xff0c;可以让开发者根据自己的需求自由扩展和定制…

颜色空间的选择

1.选择Gamma颜色空间&#xff0c;Web平台或者不支持线性空间&#xff0c;或者追求高饱和度的 2.选择Linear&#xff0c;追求真实光照和物理准确

亚信安慧AntDB数据库采集技术创新:ACC从Java到Go的转型之路

传统的指标采集方法通常使用一些命令行工具&#xff0c;如top、free等来获取系统的性能数据。然而&#xff0c;这种方法存在一些缺点。首先&#xff0c;这些命令行工具输出的数据格式通常是文本形式&#xff0c;需要进行解析和处理才能得到有用的信息&#xff0c;这增加了开发者…

Vulnhub - AI-WEB-1.0靶机教程

目录 站点信息收集 c段扫描 端口扫描 目录扫描 漏洞利用 使用 burp 抓包 查询数据库名 查询数据库下的表 查询表中的字段名 查询字段中的数据 --os-shell 上传一句话木马 下载地址&#xff1a;https://download.vulnhub.com/aiweb/AI-Web-1.0.7z 我们从站点信息收…

OpenHarmony 实战开发——ArkUI中的线程和看门狗机制

一、前言 本文主要分析ArkUI中涉及的线程和看门狗机制。 二、ArkUI中的线程 应用Ability首次创建界面的流程大致如下&#xff1a; 说明&#xff1a; • AceContainer是一个容器类&#xff0c;由前端、任务执行器、资源管理器、渲染管线、视图等聚合而成&#xff0c;提供了生…

nss做题

[NCTF 2018]签到题 1.f12在index.php中找到flag [NSSCTF 2022 Spring Recruit]ezgame 1.在js源码中就有flag [UUCTF 2022 新生赛]websign 1.打开环境后发现ctrlu和右键&#xff0c;f12都被禁用了。两种方法&#xff0c;第一种&#xff1a;禁用js&#xff1b;第二中提前打开…

亚马逊高效广告打法及数据优化,亚马逊高阶广告打法课

课程下载&#xff1a;https://download.csdn.net/download/m0_66047725/89342733 更多资源下载&#xff1a;关注我。 课程内容&#xff1a; 001.1-亚马逊的广告漏斗和A9算法的升级变化.mp4 002.2-流量入口解析和广告的曝光机制.mp4 003.3-标签理论 .mp4 004.4-不同广告类…

GoldenEye-v1(vulnhub)靶机练习实践报告

GoldenEye-v1****靶机练习实践报告 一、安装靶机 靶机是.ova文件&#xff0c;需要用VirtualBox打开&#xff0c;但我习惯于使用VMWare,因此修改靶机文件&#xff0c;使其适用于VMWare打开。 解压ova文件&#xff0c;得到.ovf文件和.vmdk文件。 用记事本打开.ovf文件并修改“…

预训练大模型

参考代码&#xff1a;https://github.com/LlamaFamily/Llama-Chinese

AI大模型在测试中的深度应用与实践案例

文章目录 1. 示例项目背景2. 环境准备3. 代码实现3.1. 自动生成测试用例3.2. 自动化测试脚本3.3. 性能测试3.4. 结果分析 4. 进一步深入4.1. 集成CI/CD管道4.1.1 Jenkins示例 4.2. 详细的负载测试和性能监控4.2.1 Locust示例 4.3. 测试结果分析与报告 5. 进一步集成和优化5.1. …

excel里如何将数据分组转置?

这个表格怎样转换为下表&#xff1f;按照国家来分组&#xff0c;把不同年份对应的不同序列值进行转置&#xff1f;&#xff1f; 这演示用数据透视表就完成这个数据转换。 1.创建数据透视表 选中数据中任意单元格&#xff0c;点击插入选项卡&#xff0c;数据透视表&#xff0c;…

【数学建模】碎纸片的拼接复原

2013高教社杯全国大学生数学建模竞赛B题 问题一模型一模型二条件设立思路 问题求解 问题一 已知 d i d_i di​为第 i i i张图片图片的像素矩阵 已知 d i d_i di​都是 n ∗ m n*m n∗m二维矩阵 假设有 N N N张图片 模型一 我们认为对应位置像素匹配为 d i [ j ] [ 1 ] d k…

clocking wizard IP核通过AXI4-Lite接口实现动态重新配置应用实例

在最近的FPGA应用中&#xff0c;应用到了基于Zynq 7000的Uart串口设计&#xff0c;为了让串口的时钟更精确&#xff0c;采用了外部时钟模式&#xff0c;如下图所示。外部时钟连接到了Clocking Wizard IP核的输出端。 在串口通信时&#xff0c;发现串口有错码出现。例如&#xf…

leetcode124 二叉树中的最大路径和-dp

题目 二叉树中的 路径 被定义为一条节点序列&#xff0c;序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点&#xff0c;且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点 root &…

C++模板方法模式

文章目录 1. 定义抽象基类&#xff08;Abstract Class&#xff09;2. 实现具体子类&#xff08;Concrete Class&#xff09;3. 使用模板方法模板方法模式的优点模板方法模式的应用场景注意事项实现示例抽象类&#xff08;模板&#xff09;具体实现类客户端代码 总结 模板方法模…