位置: 编程技术 - 正文

利用Shell解析处理XML的方法汇总(shell 解析yml)

编辑:rootadmin

推荐整理分享利用Shell解析处理XML的方法汇总(shell 解析yml),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:shell 解析配置文件,shell脚本解析文件,shell 解析参数,shell 解析配置文件,shell解析ini,shell 解析yml,shell 解析yml,shell 解析参数,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

前几天在干活的时候遇到一个需要解析处理xml文件的一个需求,当时考虑到逻辑比较复杂,因此用java慢慢搞了搞。不过这个需求经常会变,每次变化之后都要重新找到jar包的代码,改了之后还要替换原来的jar包,一来不方便修改,二来不方便统一保存代码,三来也不方便查看jar包的功能。

其实对于这种比较灵活的功能,最方便高效的做法是采用一些脚本语言,比如python,ruby等等,开发效率高,而且也能处理一些复杂逻辑。但是由于种种原因,工作中有的机器没有安装这些语言的解释器。因此不得已,研究了一波用shell脚本解析xml的方法。

说到底,shell还是不太适合处理复杂的逻辑,但是对于一些简单的查找替换等需求,用shell来搞还是挺方便的。

我这里主要采用了下面三个工具:

xmllint xpath xml2

下面就分别总结下这三个工具的用法,方便以后查阅。

xmllint

简述

xmllint其实是由一个叫libxml2的c语言库函数实现的一个小工具,因此效率比较高,对不同系统的支持度也很好,功能也比较全。他一般属于libxml2-utils这个软件包,因此类似与sudo apt install libxml2-utils的命令就可以安装。

功能

xmllint至少支持下面几个常用功能:

支持xpath查询语句 支持类shell的交互式查询 支持xml格式验证 支持dtd,xsd对xml的校验 支持编码转换 支持xml格式化 支持去空格压缩 支持时间效率统计

其实我们比较常用的功能主要也就是三个?xpath查询、去空格和格式化、校验。

比如当前有sample.xml:

执行xpath查询:

去空格:

格式化:

利用Shell解析处理XML的方法汇总(shell 解析yml)

xsd校验:

注意:校验结果信息是输出到stderr中的,工具默认会把原文件回显到stdout里,可以加?noout参数关闭stdout回显。

流传递:

xmllint默认是传递文件名,如果我们希望用通过管道传递文件流的方式传递数据,我们可以这样弄:

xpath

简述

xpath工具其实是封装了的perl脚本,本身也只有两百来行,功能比较专一,就是提供xpath的查询功能。他一般属于libxml-xpath-perl这个软件包,因此类似于sudo apt install libxml-xpath-perl的命令就可以安装。像suse之类的系统还会直接自带。

功能

不同系统中安装的版本可能不同,不过基本功能是类似的:

默认会将查询呢结果输出到stdout中,将说明信息输出到stderr中。如果为了方便收集结果,可以将stderr重定向到/dev/null,或者加上-q参数:

xpath相比xmllint的xpath功能有一点点区别很重要,如果xpath匹配了多个结果,那么xpath就会分行输出,而xmllint则会揉到一行:

xml2

简述

xml2这个工具感觉知道的人并不多,不过其实他在某些场景里跟其他命令配合能起到奇效。这个工具的开发人员的博客似乎已经挂掉了,不过目测应该用C以及libxml2库写的一个小工具。一般是在xml2软件包中,因此类似sudo apt install xml2的命令就可以安装。

功能

这个工具包含六个命令:xml2,2xml,html2,2html,csv2,2csv,功能也非常unix,就是分别将xml,html,csv格式与一种他称之为“flat format”的格式进行转换。举个例子:

这种自定义的格式非常简单而巧妙,有的表示新建节点(/books/book),有的表示给节点赋值(/books/book/name=book1),有的表示给节点的属性赋值(/books/book/@id=1)。写法跟xpath很像但又不完全一样。而且相互对应的两个命令放在一起能做到幂等。

那么这种转化命令有什么用呢?其实我们经常会遇到一些创建xml文件的需求,但是直接按照xml格式动态生成就非常麻烦,这时候用flat format做个中转就非常方便了:

上面这段代码就生成了与sample.xml一模一样的new_sample.xml.

总结

标签: shell 解析yml

本文链接地址:https://www.jiuchutong.com/biancheng/379770.html 转载请保留说明!

上一篇:Linux下.tar.xz文件的解压教程详解(linux .tar文件)

下一篇:Linux上的文件搜索命令实例详解(linux系统如何搜索文件内容)

  • 退回的所得税与增值税的财务处理?
  • 员工报销款可以公转私吗
  • 增值税需要结转到本年利润吗
  • 盘盈固定资产属于企业的会计差错
  • 分步法和分批法思维导图
  • 社会组织属于非法人组织吗为什么
  • 房地产企业承担的债务
  • 应纳税所得额就是企业所得税吗
  • 销项进项怎么转化
  • 深圳报关费用是多少
  • 老会计有多厉害
  • 私车公用税务处理办法
  • 普通发票红字冲销,需要退回原发票吗
  • 为什么餐费不能计入在差旅费
  • 质量罚款入什么科目
  • 企业进项税和销项税抵扣政策
  • 企业核算方法
  • 进项发票认证抵扣时间是每月的15号吗
  • 没有税务章的收款收据怎么做账?
  • 用友t3怎么增加现金流量项目
  • 小规模纳税人缴纳增值税的会计科目
  • 收到负数购入发票怎么办
  • windows10如何关机
  • windows更新暂停怎么恢复
  • 抵扣联和发票联丢失怎么办
  • jinjia.exe进程
  • qttask.exe是什么进程?qttask.exe是不是病毒?
  • 最小的蓝牙鼠标是哪款
  • hpzts04.exe是什么进程 有什么作用 hpzts04进程查询
  • 收到的国家电网电话
  • 因果推断的常用标准
  • 语义特征的语法学概念
  • 人工智能机器人的好处
  • php jsonp
  • 自然人办税服务大厅
  • php hash_hmac
  • 财政拨入的科技费是什么
  • 工资计提未发放,调增还是调减
  • 财务报表不申报可以领票吗
  • 固定资产投资入股是否缴纳增值税
  • 将织梦dedecms转换到wordpress
  • 商业保险 抵扣个税
  • 产品管理部门职责
  • 进项的加计抵减怎么算
  • 个体户开票超过多少认定为小规模
  • 小规模个体工商户怎么交税
  • 累计预扣法利弊
  • 农村土地征用补偿价格
  • 金税三期个税申报
  • 汇算清缴怎么申报
  • 分支机构与总机构怎么纳税?
  • 代扣代缴完税凭证抵扣期限
  • 工程施工与工程成本的区别
  • 计提工资与实发工资有差额怎么计算成本
  • 新成立公司怎么办理社保开户
  • 制造费用按什么设置明细
  • mysql获取日期年份
  • Vista 新命令收集整理完整版
  • linux中的rpm
  • winxp开机界面后老重启
  • win8.1网络不可用怎么办
  • linux系统中怎么创建目录
  • Mtdacq.exe - Mtdacq是什么进程 有什么用
  • windows8连接wifi
  • 在Linux系统中安装虚拟window
  • [置顶]bilinovel
  • bat 批处理文件
  • perl 文本文件处理
  • cocos2dx schedule
  • shell 数组变量
  • python 任务 调度 管理
  • 批处理压缩
  • node.js使用教程
  • javascript data
  • js正则表达式变量
  • python:\n
  • node express 路由
  • 地方税务局发票查询
  • 地税是什么税种
  • 苹果关税多少钱一个
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设