Ответ 1
$myString =~ s/^\s*(.*?)\s*$/$1/;
Это позволит обрезать пробелы с обеих сторон.
только справа:
$myString =~ s/\s*$//;
Если я объявил переменную $myString
со значением '3 '
(обратите внимание на пробел).
Есть ли какая-либо функция для удаления пробела для возвращаемого значения.
Немного, как SomeFun($myString)
, верните '3'
(без пробела).
#!C:\Perl\bin\perl.exe
use strict;
use warnings;
use Data::Dumper;
my $fh = \*DATA;
print Dumper parse_constant_spec( $fh );
# Parse a constant spec file.
# Pass in a handle to process.
# As long as it acts like a file handle, it will work.
sub parse_constant_spec {
my $fh = shift;
my %spec;
# Until file is done:
# Read in a whole block
while( my $block = read_block($fh) ) {
# Parse the and return key/value pairs for a hash.
my %constant = parse_block( $block );
# Store a ref to the hash in a big hash of all blocks, keyed by constant_name.
$spec{ $constant{const_name} } = \%constant;
}
# Return ref to big hash with all block data
return \%spec;
}
# Read a constant definition block from a file handle.
# void return when there is no data left in the file.
# Otherwise return an array ref containing lines to in the block.
sub read_block {
my $fh = shift;
my @lines;
my $block_started = 0;
while( my $line = <$fh> ) {
$block_started++ if $line =~ /^constant/;
if( $block_started ) {
last if $line =~ /^\s*$/;
push @lines, $line;
}
}
return \@lines if @lines;
return;
}
sub parse_block {
my $block = shift;
my ($start_line, @attribs) = @$block;
my %constant;
# Break down first line:
# First separate assignment from option list.
my ($start_head, $start_tail) = split /=/, $start_line;
# work on option list
my @options = split /\s+/, $start_head;
# Recover constant_name from options:
$constant{const_name} = pop @options;
$constant{options} = \@options;
# Now we parse the value/type specifier
@constant{'type', 'value' } = parse_type_value_specifier( $start_tail );
# Parse attribute lines.
# since we've already got multiple per line, get them all at once.
chomp @attribs;
my $attribs = join ' ', @attribs;
# we have one long line of mixed key = "value" or key = <TYPE VALUE>
@attribs = $attribs =~ /\s*(\w+\s+=\s+\w+\s+|\w+\s+=\s+".*?"|\w+\s+=\s+<.*?>)\s*/g;
for my $attrib ( @attribs ) {
warn "$attrib\n";
my ($name, $value) = split /\s*=\s*/, $attrib;
if( $value =~ /^"/ ) {
$value =~ s/^"|"\s*$//g;
}
elsif( $value =~ /^</ ) {
$value = [ parse_type_value_specifier( $start_tail ) ];
}
else {
warn "Bad line";
}
$constant{ $name } = $value;
}
return %constant;
}
sub parse_type_value_specifier {
my $tvs = shift;
my ($type, $value) = $tvs =~ /<(\w+)\s+(.*?)>/;
return $type, $value;
}
__DATA__
constant fixup GemEstabCommDelay = <U2 20>
vid = 6
name = "ESTABLISHCOMMUNICATIONSTIMEOUT"
units = "s"
min = <U2 0>
max = <U2 1800>
default = <U2 20>
constant fixup private GemConstantFileName = <A "C:\\TMP\\CONST.LOG">
vid = 4
name = "" units = ""
constant fixup private GemAlarmFileName = <A "C:\\TMP\\ALARM.LOG">
vid = 0
name = ""
units = ""
Вывод:
D:\learning\perl>hello1.pl
vid = 6
Bad line at D:\learning\perl\hello1.pl line 102, <DATA> line 8.
name = "ESTABLISHCOMMUNICATIONSTIMEOUT"
units = "s"
min = <U2 0>
max = <U2 1800>
default = <U2 20>
vid = 4
Bad line at D:\learning\perl\hello1.pl line 102, <DATA> line 13.
name = ""
units = ""
vid = 0
Bad line at D:\learning\perl\hello1.pl line 102, <DATA> line 18.
name = ""
units = ""
$VAR1 = {
'GemAlarmFileName' => {
'vid' => '0 ',
'options' => [
'constant',
'fixup',
'private'
],
'value' => '"C:\\\\TMP\\\\ALARM.LOG"',
'name' => '',
'type' => 'A',
'const_name' => 'GemAlarmFileName',
'units' => ''
},
'GemEstabCommDelay' => {
'vid' => '6 ',
'options' => [
'constant',
'fixup'
],
'value' => '20',
'min' => [
'U2',
'20'
],
'name' => 'ESTABLISHCOMMUNICATIONSTIMEOUT',
'max' => [
'U2',
'20'
],
'default' => [
'U2',
'20'
],
'type' => 'U2',
'units' => 's',
'const_name' => 'GemEstabCommDelay'
},
'GemConstantFileName' => {
'vid' => '4 ',
'options' => [
'constant',
'fixup',
'private'
],
'value' => '"C:\\\\TMP\\\\CONST.LOG"',
'name' => '',
'type' => 'A',
'const_name' => 'GemConstantFileName',
'units' => ''
}
};
D:\learning\perl>
Вы могли заметить, что 'vid' => '0 ',
(обратите внимание на пробел)
Код выше из ответ. Я изучаю это.: -)
Спасибо.
$myString =~ s/^\s*(.*?)\s*$/$1/;
Это позволит обрезать пробелы с обеих сторон.
только справа:
$myString =~ s/\s*$//;
Если ваше свободное пространство просто пробелы, то следующий код удалит все пробелы:
$mystring =~ tr/ //ds;
sub trim($)
{
my $string = shift;
$string =~ s/^\s+//;
$string =~ s/\s+$//;
return $string;
}
print trim($myString)
Попробуйте следующее:
# Delete leading/trailing whitespace.
$string =~ s/^\s+|\s+$//g;
Другим потенциальным альтернативным решением является Text:: Trim из CPAN, который будет "удалять ведущие и/или завершающие пробелы из строк". Он имеет функцию trim
, которая может удовлетворить ваши потребности.
sub trim
{
my $str = $_[0];
$str=~s/^\s+|\s+$//g;
return $str;
}
print trim(" 4 ");
Вот подпрограмма, которая позволит вам удалить ведущую и завершающую пробелы из строки, а также удалить лишние пробелы из строки и заменить ее на отдельные пробелы.
sub unspace { my @stringer = @_ ? @_ : $; $ = join( ' ', split(' ')) for @stringer; return wantarray ? @stringer : "@stringer"; }
$MySpacedString = ' String with tabs double-spaces and other whitespace areas. '; $MyCleanString = unspace($MySpacedString);
Просто просмотрев вашу программу, я нашел 3 места, которые могли быть улучшены или исправлены.
Извиняюсь, если мой код плохо форматируется.: - (
В вашей функции parse_block (...) есть 3 элемента, которые требуют внимания.
@attribs = $attribs =~ /\s*(\w+\s+=\s+\w+\s+|\w+\s+=\s+".*?"|\w+\s+=\s+<.*?>)\s*/g;
Чтобы исключить пробел после vid = > '6', просто не включайте \s + в конец вашего первого подрежима.
Напишите его как:
@attribs = $attribs =~ /\s*(\w+\s+=\s+\w+|\w+\s+=\s+".*?"|\w+\s+=\s+<.*?>)\s*/g;
$value = [ parse_type_value_specifier( $start_tail ) ];
Вместо этого вы хотите:
$value = [ parse_type_value_specifier( $value ) ];
(Обратите внимание, что параметр функции должен быть $value, а не $start_tail.) Вероятно, вы этого не заметили.
В цикле для @attributes "else" в условии if/else выполняется, когда "значение" имеет равное значение, (нет "или"... "элементов в" значении").
Обновление: Изменен параметр в
parse_type_value_specifier(...)до $value. Это было (неправильно) указано как $attrib.
Удалить пробелы из переменной $test (eq rtrim(ltrim(@sStr))
из Transact SQL:
$test =~s/^\s*(\S*)\s*$/$1/;
Если вы хотите использовать модуль CPAN, тогда String::Util
или несколько более экономичный Text::Trim
будет возможным выбором.
Обрезка нитей - это один из тех байкеров, которые все любят строить! См. Короткий perlmaven tutorial @szabgab для небольшого примера удовольствия TIMTOWDI.
Я предлагаю вам использовать модуль Text::Trim
, который предоставляет ltrim
, rtrim
и trim
, все из которых будут обрезать переданные параметры или $_
, если вы не дадите никаких параметров. Это не основной модуль, поэтому может потребоваться установка