簡體   English   中英

在Perl中使用正則表達式進行匹配

[英]match using regex in perl

嗨,我正在嘗試從perl的文本文件中提取一些數據。 我的檔案看起來像這樣

Name:John
FirstName:Smith
Name:Alice
FirstName:Meyers
....

我希望我的弦看起來像John SmithAlice Meyers

我嘗試過類似的方法,但遇到了困難,不知道如何繼續

 while (<INPUT>) {
        if (/^[Name]/) {
            $match =~ /(:)(.*?)(\n) / 
            $string = $string.$2;
        }
        if (/^[FirstName]/) {
            $match =~ /(:)(.*?)(\n)/ 
            $string = $string.$2;
        }

}

我想做的是,當我匹配Name或FirstName復制到:\\n之間的內容時,卻感到困惑,分別是$1$2

這會將您的名字和姓氏放在哈希中:

use strict;
use warnings;
use Data::Dumper;

open my $in, '<', 'in.txt';
my (%data, $names, $firstname);

while(<$in>){
    chomp;
    ($names) = /Name:(.*)/ if /^Name/; 
    ($firstname) = /FirstName:(.*)/ if /^FirstName/;
    $data{$names} = $firstname;
}

print Dumper \%data;

通過perl一線,

$ perl -0777 -pe 's/(?m).*?Name:([^\n]*)\nFirstName:([^\n]*).*/\1 \2/g' file
John Smith
Alice Meyers
while (<INPUT>) {
   /^([A-Za-z])+\:\s*(.*)$/;
   if ($1 eq 'Name') {
      $surname = $2;
   } elsif ($1 eq 'FirstName') {
      $completeName = $2 . " " . $surname;
   } else {
      /* Error */
   }
}

您可能需要添加一些錯誤處理,例如,確保Name始終跟在FirstName之后,依此類推。

$ 1 $ 2 $ 3 .. $ N,它是()在正則表達式中的捕獲結果。

如果執行類似的操作,就無法避免使用$ 1之類的變量。

my ($matched1,$matched2) = $text =~ /(.*):(.*)/

my $names = [];
my $name = '';
while(my $row = <>){
  $row =~ /:(.*)/;
  $name = $name.' '.$1;
  push(@$names,$name) if $name =~ / /;
  $name = '' if $name =~ / /;

}

`而(<>){

}`

open (FH,'abc.txt');
my(%hash,@array);
map{$_=~s/.*?://g;chomp($_);push(@array,$_)} <FH>;
%hash=@array;
print Dumper \%hash;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM