gpt4 book ai didi

Perl:如何从特定模式开始逐字读取文本文件?

转载 作者:行者123 更新时间:2023-12-02 00:58:16 24 4
gpt4 key购买 nike

我正在尝试编写一个脚本来读取以空格分隔的文本文件并识别特定模式 PATTERN。识别 PATTERN 后,脚本应读取 RANDOM_NUMBER 个以 PATTERN 开头的单词。例如,假设 PATTERNa 并且 RANDOM_NUMBER7。然后对于这个文本文件:

1 2 3 4 5 6
a b c d e f
g h i j k j

我想得到:

a b c d e f
g

作为输出。

到目前为止,我已经到了识别这些模式的地步,但我不知道之后如何处理它。阅读单词的最佳方式是什么?

顺便说一句,我看过Read text file in Perl word by word instead of line by line这对我的目的来说有点太模糊了。此外,答案并未就代码的作用提供太多解释。

最佳答案

好的,所以这里的技巧是设置 $/ - 记录分隔符。如果我们将它设置为 ' ',我们可以一次迭代一个“单词”。

然后我们可以使用范围运算符来“检测”我们是否在我们的模式之间。

local $/ = ' ';

while ( <DATA> ) {
if ( m/a/ .. 10 ) { print; }
}

现在,这会将 from a 打印到“field 10”——这不是特别有用,因为“count”从文件的开头开始。 (由

因此,我们可能希望在看到的条件为真时“触发”,并继续进行其他多次迭代:

#!/usr/bin/perl
use strict;
use warnings;

local $/ = ' ';

while (<DATA>) {
if (m/a/) {
print;
for ( 2 .. 7 ) { print scalar <DATA>; } #2 because we already have "1"
last; #assuming we only want to do this once.
}
}


__DATA__
1 2 3 4 5 6
a b c d e f
g h i j k j

打印:

a b c d e f 
g

关于Perl:如何从特定模式开始逐字读取文本文件?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31882086/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com