perl 用 XML::DOM 解析 Freeplane.mm文件,生成测试用例.csv文件

Perl 官网 www.cpan.org

https://strawberryperl.com/ 下载网速太慢了

建议从 https://download.csdn.net/download/qq_36286161/87892419

下载 strawberry-perl-5.32.1.1-64bit.zip 约105MB

解压后安装.msi,装完后有520MB+,建议安装在D:盘。

运行 cmd

cpan

install XML::DOM

在云计算中,解析XML元素和属性是一种常见的操作,因为XML是一种常见的数据交换格式,可以用来表示各种不同的数据结构和信息。Perl 是一种过去流行的脚本语言,可以用来处理各种文本数据,包括XML数据。

在Perl 中,可以使用各种模块和函数来解析 XML元素和属性。其中,常用的模块是 XML::DOM,它提供了一组完整的XML解析和处理函数,可以方便地解析XML文档中的元素和属性。

例如,下面是一个使用 XML::DOM 模块 解析 XML元素和属性 的示例代码:

先编写一个测试程序 test_xml_dom.pl 如下

perl 复制代码
#!/usr/bin/perl
use 5.010;
use strict;
use warnings;
use utf8;
use XML::DOM;
use Data::Dumper;

if ($#ARGV != 0){
    die "You must specify a file.xml to parse";
}
my $file = shift @ARGV;

my $parser = new XML::DOM::Parser;
my $doc = $parser->parsefile($file)
         or die "cannot read file.xml\n";

my $f2 = $file .'.txt';
# 写入文件
open(my $fw, '>:encoding(UTF-8)', $f2) or die "cannot open file '$f2' $!";

# print all TEXT attributes of all node elements
my $nodes = $doc->getElementsByTagName('node');
my $n = $nodes->getLength;

for (my $i=0; $i < $n; $i++)
{
    my $node = $nodes->item ($i);
    my $TEXT = $node->getAttributeNode('TEXT');
    print $fw $TEXT->getValue ."\n";
}
close($fw);
# Avoid memory leaks - for garbage collection
$doc->dispose;

运行 perl test_xml_dom.pl your_test.xml

再编写 xml_dom_parser.pl 如下

perl 复制代码
#!/usr/bin/perl
use 5.010;
use strict;
use warnings;
use utf8;
use XML::DOM;

# 解析 Freeplane.mm文件,生成测试用例.csv文件
#  xt: 应用系统名的英文或拼音缩写
# zd?: 字段?的拼音缩写
# zd1: 模块名
# zd2: 功能名
# zd3: 正向 或 反向
# zd4: 测试要点
# zd5: 执行步骤
# zd6: 预期结果
# csylms:测试用例描述

if ($#ARGV != 0){
    die "You must specify a file.xml to parse";
}
my $file = shift @ARGV;

my $parser = new XML::DOM::Parser;
my $doc = $parser->parsefile($file)
         or die "cannot read file.xml\n";

my $f2 = $file .'.csv';
# 写入文件
open(my $fw, '>:encoding(UTF-8)', $f2) or die "cannot open file '$f2' $!";
print $fw "应用系统名,模块名,测试用例描述,正反向,执行步骤,预期结果\n";

# 要检查一个字符串是否以另一个字符串开始,可使用字符串比较:
sub startsWith {  
    my ($str, $prefix) = @_;  
    return substr($str,0, length($prefix)) eq $prefix;
} 

# 获取根节点  
my $root = $doc->getFirstChild;
my $nodes = $root->getElementsByTagName('node');
my $node = $nodes->item(0);
say ref($node);
my $xt = $node->getAttributeNode('TEXT')->getValue;
my ($zd1,$zd2,$zd3,$zd4,$zd5,$zd6,$txt,$csylms);
$zd5 =''; $zd6 ='';
foreach my $node1 ($node->getChildNodes){
if($node1->getNodeType == ELEMENT_NODE and $node1->getTagName eq 'node'){
  my $t1 = $node1->getAttributeNode('TEXT');
  if ($t1){ $zd1 = $t1->getValue;}
  foreach my $node2 ($node1->getChildNodes){
  if($node2->getNodeType == ELEMENT_NODE and $node2->getTagName eq 'node'){
    my $t2 = $node2->getAttributeNode('TEXT');
    if ($t2){ $zd2 = $t2->getValue;}
    foreach my $node3 ($node2->getChildNodes){
    if($node3->getNodeType == ELEMENT_NODE and $node3->getTagName eq 'node'){
       my $t3 = $node3->getAttributeNode('TEXT');
       if ($t3){ $zd3 = $t3->getValue;}
       foreach my $node4 ($node3->getChildNodes){
       if($node4->getNodeType == ELEMENT_NODE and $node4->getTagName eq 'node'){
         my $t4 = $node4->getAttributeNode('TEXT');
         if ($t4){ $zd4 = $t4->getValue;}
         foreach my $node5 ($node4->getChildNodes){
         if($node5->getNodeType == ELEMENT_NODE and $node5->getTagName eq 'node'){
           my $t5 = $node5->getAttributeNode('TEXT');
           if ($t5){ $txt = $t5->getValue;
             if (startsWith($txt, '步骤:')){
               $zd5 = substr($txt, 3);
             } elsif (startsWith($txt, '预期结果:')){
               $zd6 = substr($txt, 5);
               $csylms = $zd2 .'-'. $zd4; # 测试用例描述
               print $fw "$xt,$zd1,$csylms,$zd3,$zd5,$zd6\n";
             } else {
               $zd5 =''; $zd6 ='';
             }
           }
        }}
      }}
    }}
  }}
}}
close($fw);
# Avoid memory leaks - for garbage collection
$doc->dispose;

运行 perl xml_dom_parser.pl your_test.mm

perl 复制代码
应用系统名,模块名,测试用例描述,正反向,执行步骤,预期结果
应用系统,模块1,功能11-测试要点111,正向,1.步骤,1.结果
应用系统,模块1,功能11-测试要点112,正向,2.步骤,2.结果
应用系统,模块1,功能11-要点111,反向,3.步骤,3.结果
应用系统,模块1,功能11-要点112,反向,4.步骤,4.结果
应用系统,模块2,功能21-测试要点211,正向,5.步骤,5.结果
应用系统,模块2,功能21-测试要点212,正向,6.步骤,6.结果
应用系统,模块2,功能21-要点211,反向,7.步骤,7.结果
应用系统,模块2,功能21-要点212,反向,8.步骤,8.结果

参阅:XML::DOM - A perl module for building DOM Level 1 compliant document structures - metacpan.org

相关推荐
小百菜18 小时前
dom4j实现xml转map,xml转json字符串
xml·json·xml转map·xml转json
玄客)19 小时前
XML标记语言
xml
 嘘 1 天前
文件操作:Xml转Excel
xml·python·excel
q567315231 天前
使用 Python 编辑 XML 文件中的文本字段
xml·java·数据库·python·sqlite
爱敲代码的小冰2 天前
java mapper 的 xml讲解
xml·java·mybatis
子非鱼9212 天前
【Ajax】原生Ajax与jQuery中的Ajax
xml·ajax·node.js·jquery
天天进步20152 天前
X2JS: XML与JSON的完美转换工具
xml·json
法迪3 天前
解读JobScheduler的jobs.xml
xml·功耗
残花月伴3 天前
配置文件格式(xml、properties、yml/yaml)
xml·java
zhangxiang_ouc3 天前
Caché/IRIS file2Xml 一个将文件转换成Studio导出的xml格式的工具
xml