获取文件的最后修改时间并格式化成相应字符串
# shell
mTime=`stat -c %Y $dir`
dirTime=`date '+%Y%m%d%H%M%S' -d @$mTime`
\# powershell
\$dirTime=$((Get-Item publish).lastwritetime).ToString('yyyyMMddhhmm')
替换文本并写入文件
\# powershell
\$(Get-Content test.txt) | Foreach-Object {$_ -replace ("1","2")} | Out-File test.txt
\# powershell
修改读取xml
$xmldata = [xml](Get-Content test.xml)
修改成员项:
\<**child1** attribute1="xxx'"\>
\<*child2*>xxxxxx</*child2*\>
\<*child2* attribute1="bbbbbb"\>
\<child3\>aaaaaa\<\/child3\>
\<\/*child2*\>
\<*child2*\>xxxxxx\<\/*child2*\>
\<\/**child1** \>
eg1:(child1同类型只有一个节点可以直接用 不加索引,child2同类型有多个需要加索引(从0开始)选取哪个,child3同类型只有1个节点,可以直接使用并赋值)1
\$xmldata.child1.child2[1].child3= "xxxxxx"
即可把aaaaaa改成xxxxxx
eg2:
\$xmldata.child1.child2[2].SetAttribute("attribute1", "xxxxxx")
即可把bbbbbb改成xxxxxx
若不存在bbbbbb使用这个命令会增加一个attribute1
最后保存更新到当前xml 也可以保存到其他xml
获取当前路径:
\$curPath = Split-Path -Parent $MyInvocation.MyCommand.Definition
由于Save函数里必须装绝对路径,若只传相对路径Save函数会自动加一个前面的User路径,会导致保存到非期望的地方或直接找不到路径报错,所以这里可以获取一下当前路径,当然函数里也可以传绝对路径
\$xmldata.Save("\$curPath\test.xml")
文件操作与XML编辑技巧
本文介绍如何使用Shell和PowerShell脚本获取文件的最后修改时间,并格式化为指定字符串形式,同时展示了如何批量替换文本内容及读取、修改XML文件的具体方法。
505

被折叠的 条评论
为什么被折叠?



