如何在 Perl 中修剪文件的内容?

发布于 2024-09-25 20:14:58 字数 1078 浏览 4 评论 0原文

我想在 Perl 中将文件的内容从某个字符删除到文件中的某个字符。我如何使用脚本来做到这一点?

文件有这样的:

Syslog logging: enabled (11 messages dropped, 2 messages rate-limited,
                0 flushes, 0 overruns, xml disabled, filtering disabled)
    Console logging: level informational, 81 messages logged, xml disabled,
                     filtering disabled
    Monitor logging: level debugging, 0 messages logged, xml disabled,
                     filtering disabled
    Buffer logging: level informational, 28 messages logged, xml disabled,
                    filtering disabled
    Logging Exception size (4096 bytes)
    Count and timestamp logging messages: disabled

No active filter modules.

    Trap logging: level informational, 83 message lines logged

Log Buffer (4096 bytes):

*Oct  4 13:42:03.210: %SEC_LOGIN-5-LOGIN_SUCCESS: Login Success [user: ] [Source: ] [localport: ] at UTC Mon Oct 4 2010

修剪后的新文件应该是这样的

*Oct  4 13:42:03.210: %SEC_LOGIN-5-LOGIN_SUCCESS: Login Success [user: ] [Source: ] [localport: ] at UTC Mon Oct 4 2010

I would like to remove contents of a file from a certain character to a certain character in the file in Perl. How do I do that using a script?

The file has this:

Syslog logging: enabled (11 messages dropped, 2 messages rate-limited,
                0 flushes, 0 overruns, xml disabled, filtering disabled)
    Console logging: level informational, 81 messages logged, xml disabled,
                     filtering disabled
    Monitor logging: level debugging, 0 messages logged, xml disabled,
                     filtering disabled
    Buffer logging: level informational, 28 messages logged, xml disabled,
                    filtering disabled
    Logging Exception size (4096 bytes)
    Count and timestamp logging messages: disabled

No active filter modules.

    Trap logging: level informational, 83 message lines logged

Log Buffer (4096 bytes):

*Oct  4 13:42:03.210: %SEC_LOGIN-5-LOGIN_SUCCESS: Login Success [user: ] [Source: ] [localport: ] at UTC Mon Oct 4 2010

And the new file after the trimming should be this

*Oct  4 13:42:03.210: %SEC_LOGIN-5-LOGIN_SUCCESS: Login Success [user: ] [Source: ] [localport: ] at UTC Mon Oct 4 2010

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

任性一次 2024-10-02 20:14:58

您没有提供足够的信息。但这听起来像是可以从命令行完成的事情。您的解决方案可能如下所示:

$ perl -ne 'print unless /start_skip/ .. /end_skip/' in.txt > out.txt

更新: 看过您的扩展说明后,您似乎只需要以星号开头的行。

$ perl -ne 'print if /^\*/' in.txt > out.txt

You don't give anywhere near enough information. But it sounds like something that can be done from the command line. Your solution will probably look something like this:

$ perl -ne 'print unless /start_skip/ .. /end_skip/' in.txt > out.txt

Update: Having seen your expanded explanation, it looks like you only want lines that start with an asterisk.

$ perl -ne 'print if /^\*/' in.txt > out.txt
×纯※雪 2024-10-02 20:14:58

如果我很了解您的需求,您可以执行以下操作:

我已根据您的新规范进行了更新

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

my $in_file = 'foo.txt';
my $out_file = 'bar.txt';

open my $fh_in, '<', $in_file or die "unable to open '$in_file' for reading: $!";
open my $fh_out, '>', $out_file or die "unable to open  '$out_file' for writing: $!";

while(<$fh_in>) {
    chomp;

    # updated according to new requirements
    next if (/^Syslog logging/ .. /^Log Buffer/);
    next if (/^$/);

    print $fh_out $_,"\n";
}
close $fh_in;
close $fh_out;

此脚本读取文件 foo.txt 并将行写入文件 bar.txt 除了 begin_skipend_skip 之间的内容。

begin_kipend_skip 可以是任何正则表达式。

If i well understand your needs, you can do something like :

I've updated according to your new specifications

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

my $in_file = 'foo.txt';
my $out_file = 'bar.txt';

open my $fh_in, '<', $in_file or die "unable to open '$in_file' for reading: $!";
open my $fh_out, '>', $out_file or die "unable to open  '$out_file' for writing: $!";

while(<$fh_in>) {
    chomp;

    # updated according to new requirements
    next if (/^Syslog logging/ .. /^Log Buffer/);
    next if (/^$/);

    print $fh_out $_,"\n";
}
close $fh_in;
close $fh_out;

This script reads the file foo.txt and write lines into file bar.txt except those between begin_skip and end_skip included.

begin_kip and end_skip can be any regex.

寒尘 2024-10-02 20:14:58

嗯,问题不是很清楚。我猜你想删除文件中的某些字符串。

#!/usr/bin/perl

$filename = $ARGV[0];
$a = $ARGV[1];
$b = $ARGV[2];

open (FILE, $filename) || die ("Can't open the file");
open (INFILE, ">$filename.tmp") || die ("Can't open the temp file");

while ($line = <FILE>) {
    $line =~ s/$a.*$b/$a$b/g;
    print INFILE $line
}
close (INFILE);
close (FILE);

我猜你所期待的是这里的“$line =~ s/$a.*$b/$a$b/g;”它只替换字符串之间的内容,而不替换实际的字符串。你可以简单地调用 sed 脚本

sed 's/a.*b/ab/g' file

Hmm, the question is not very clear. I guess you want to delete certain strings in a file.

#!/usr/bin/perl

$filename = $ARGV[0];
$a = $ARGV[1];
$b = $ARGV[2];

open (FILE, $filename) || die ("Can't open the file");
open (INFILE, ">$filename.tmp") || die ("Can't open the temp file");

while ($line = <FILE>) {
    $line =~ s/$a.*$b/$a$b/g;
    print INFILE $line
}
close (INFILE);
close (FILE);

I guess what you are expecting is in here "$line =~ s/$a.*$b/$a$b/g;" It only replaces the content between the string but not the actual string. You could simply call sed script

sed 's/a.*b/ab/g' file
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文