我有一个包含多个表的HTML文件(所有表都有相同数量的列和相同的列名)。这些表由其他HTML标记分隔。
对于每个表中的每一行,我想更改单元格1和单元格3的值。
这是我到目前为止(感谢@depesz):
#!/usr/bin/env perl
use strict;
use warnings;
use utf8;
use open qw( :std :utf8 );
use HTML::TreeBuilder;
my $input_file_name = shift;
my $tree = HTML::TreeBuilder->new();
$tree->parse_file( $input_file_name ) or die "Cannot open or parse $input_file_name\n";
$tree->elementify();
my @tables = $tree->find_by_tag_name( 'table' );
for my $table (@tables) {
foreach my $row ($table->find_by_tag_name('tr')) {
foreach my $column ($table->find_by_tag_name('td')) {
# how do I change the text of first and 3rd column text to "removed"
}
}
}
print $tree->as_HTML();
exit;
它非常适合迭代HTML文件中的所有行。我只是不确定如何更改第1列和第3列中的文本。
答案 0 :(得分:3)
HTML::TreeBuilder::XPath
模块允许更方便地访问文档中的HTML节点。
以此程序为例。它似乎做你需要的。
use strict;
use warnings;
use HTML::TreeBuilder::XPath;
my $tree = HTML::TreeBuilder::XPath->new_from_file('anon.html');
for my $table ($tree->findnodes('//table')) {
my $row = 0;
for my $tr ($table->findnodes('//tr')) {
$row++;
for my $td ($tr->findnodes('td[position() = 1 or position() = 3]')) {
$td->delete_content;
$td->push_content("name$row");
}
}
}
print $tree->as_HTML('<>&', ' ');