[英]how to get number of commit each day from xml subversion log file with javascript, php, shell script?
具有XML Subversion提交日志:
<?xml version="1.0"?>
<log>
<logentry
revision="2">
<author>20070299</author>
<date>2012-06-06T05:23:21.999470Z</date>
<msg>add part</msg>
</logentry>
<logentry
revision="1">
<author>20070299</author>
<date>2012-05-22T08:35:55.663875Z</date>
<msg></msg>
</logentry>
</log>
我想要一个结果,该结果是按日期和每天在我的网站php-javascript上提交的次数分组的。 与此类似:
date[0]=2012-05-22
value[0]=1
date[1]=2012-05-23
value[1]=0
...
date[15]=2012-06-06
value[15]=1
有解决方案吗?
我咨询了此链接
但这不起作用,非结果非错误日志(Apache,PHP),而且我不知道如何从PHP代码向JavaScript代码发送$ number []
您可以使用XPath:
$ xmllint --shell foo.xml
/ > cat //log/*[@revision]/@revision
-------
revision="2"
-------
revision="1"
/ > cat //log/*[@revision]/date/text()
-------
2012-06-06T05:23:21.999470Z
-------
2012-05-22T08:35:55.663875Z
/ >
它在外壳中,但是您可以使用任何喜欢的语言在XPath表达式上进行迭代。
! 如果这里有人知道如何告诉XPath仅获取revision="2"
的数字,请告诉我们=)
我意识到您正在寻求Linux解决方案,但是由于此处没有提供任何帮助,因此是使用PowerShell(因此仅Windows)实现目标的一种方法。 也许通过介绍此算法,其他贡献者可以为您将其映射到Linux Shell命令。
([xml](svn log -v --xml)).log.logentry |
Select-Object -Property `
Author, `
@{n='Revision'; e={([int]$_.Revision)}}, `
@{n='Date'; e={Get-Date $_.Date }}, `
Paths |
Group-Object {$_.Date.ToString("yyyy-MM-dd")} |
Sort-Object name -Descending |
Select-Object @{n='Date'; e={$_.Name}}, Count |
Format-Table -AutoSize
您可能会猜测代码在做什么,即使在PowerShell中没有流利性也是如此,但这是关键点的摘要:
Select-Object
语句(5行)提取出XML元素和属性,将它们转换为PowerShell对象的字段。 Revision和Date被压缩为适当的类型,使它们比字符串数据更有用。 Group-Object
语句将现在是真实日期的对象转换为适合排序的格式。 Select-Object
语句只是将默认组名(名称和计数)修改为更相关的名称(日期和计数)。 Format-Table
使结果列的大小紧凑。 这是系统输出的一部分:
Date Count
---- -----
2012-06-29 4
2012-06-28 6
2012-06-27 8
2012-06-26 16
2012-06-25 1
2012-06-24 1
2012-06-22 5
2012-06-21 8
2012-06-20 8
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.