- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想获取在 PostgreSQL 工件上上传的最新 tar 文件的名称,并希望自动化相同的过程。
我指的是:https://ftp.postgresql.org/pub/odbc/versions/src/
我正在从上面的 URL 中提取要解析的 XML
XML 文件看起来像这样:
<html>
<head><title>Index of /pub/odbc/versions/src/</title></head>
<body bgcolor="white">
<h1>Index of /pub/odbc/versions/src/</h1><hr><pre><a href="../">../</a>
<a href="psqlodbc-11.00.0000.tar.gz">psqlodbc-11.00.0000.tar.gz</a> 17-Nov-2018 13:50 918461
<a href="psqlodbc-11.01.0000.tar.gz">psqlodbc-11.01.0000.tar.gz</a> 24-May-2019 14:28 919372
<a href="psqlodbc-12.00.0000.tar.gz">psqlodbc-12.00.0000.tar.gz</a> 11-Oct-2019 14:14 920713
<a href="psqlodbc-12.01.0000.tar.gz">psqlodbc-12.01.0000.tar.gz</a> 07-Jan-2020 13:53 932672
<a href="psqlodbc-12.02.0000.tar.gz">psqlodbc-12.02.0000.tar.gz</a> 26-May-2020 13:01 937847
<a href="psqlodbc-13.00.0000.tar.gz">psqlodbc-13.00.0000.tar.gz</a> 19-Nov-2020 09:53 940031
<a href="psqlodbc-13.01.0000.tar.gz">psqlodbc-13.01.0000.tar.gz</a> 02-May-2021 12:27 941064
<a href="psqlodbc-7.2.3.tar.gz">psqlodbc-7.2.3.tar.gz</a> 16-Oct-2002 09:09 367168
<a href="psqlodbc-7.2.4.tar.gz">psqlodbc-7.2.4.tar.gz</a> 12-Nov-2002 08:41 406385
<a href="psqlodbc-7.2.5.tar.gz">psqlodbc-7.2.5.tar.gz</a> 29-Nov-2002 16:10 415885
</pre></hr></body>
</html>
artifactCount=$(xmllint --xpath "count(//a)" psql.xml)
latestModified="20010101"
for (( i=2; i<=${artifactCount}; i++ ))
do
dateModified=$(xmllint --xpath "string(//pre/text()[$i])" psql.xml)
dateModified=$(echo ${dateModified} | awk '{$NF="";sub(/[ \t]+$/,"")}1')
dateModified=$(echo ${dateModified} | awk '{$NF="";sub(/[ \t]+$/,"")}1')
dateModified=$(date -d "$dateModified" +%Y%m%d)
if [ ${dateModified} -gt ${latestModified} ]
then
latestModified=${dateModified}
j=${i}
fi
done
psqlfile=$(xmllint --xpath "string(//a[${j}]/text())" psql.xml)
echo "Latest file found : ${psqlfile} modified on ${latestModified} "
psqlversion=${psqlfile#"psqlodbc-"}
psqlversion=${psqlversion%".tar.gz"}
最佳答案
xmllint
无法打开 url,仅支持 XPath 1.0,我上次检查过。我建议你给 xidel试一试。
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e 'x:lines(//pre)'
../
psqlodbc-07.03.0100.tar.gz 15-May-2003 15:56 446075
psqlodbc-07.03.0200.tar.gz 22-Oct-2003 13:46 451263
[...]
psqlodbc-7.2.5.tar.gz 29-Nov-2002 16:10 415885
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
x:lines(//pre)[position() gt 1]
'
psqlodbc-07.03.0100.tar.gz 15-May-2003 15:56 446075
psqlodbc-07.03.0200.tar.gz 22-Oct-2003 13:46 451263
psqlodbc-08.00.0100.tar.gz 02-Mar-2005 14:35 586241
[...]
psqlodbc-7.2.5.tar.gz 29-Nov-2002 16:10 415885
(
x:lines()
是
tokenize(...,'\r\n?|\n')
的简写,并将输入转换为一个序列,其中每个新行都是另一个项目)
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
x:lines(//pre)[last()] ! tokenize(.,"\s{2,}")
'
psqlodbc-7.2.5.tar.gz
29-Nov-2002 16:10
415885
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
x:lines(//pre)[last()] ! parse-ietf-date(tokenize(.,"\s{2,}")[2])
'
2002-11-29T16:10:00Z
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
for $release in x:lines(//pre)[position() gt 1]
order by parse-ietf-date(tokenize($release,"\s{2,}")[2])
return $release
'
psqlodbc-7.2.3.tar.gz 16-Oct-2002 09:09 367168
psqlodbc-7.2.4.tar.gz 12-Nov-2002 08:41 406385
psqlodbc-7.2.5.tar.gz 29-Nov-2002 16:10 415885
[...]
psqlodbc-13.01.0000.tar.gz 02-May-2021 12:27 941064
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
(
for $release in x:lines(//pre)[position() gt 1]
order by parse-ietf-date(tokenize($release,"\s{2,}")[2])
return $release
)[last()]
'
psqlodbc-13.01.0000.tar.gz 02-May-2021 12:27 941064
$ xidel -s https://ftp.postgresql.org/pub/odbc/versions/src/ -e '
resolve-uri(
(
for $release in x:lines(//pre)[position() gt 1]
let $item:=tokenize($release,"\s{2,}")
order by parse-ietf-date($item[2])
return $item[1]
)[last()]
)
'
https://ftp.postgresql.org/pub/odbc/versions/src/psqlodbc-13.01.0000.tar.gz
关于xml - 使用 shell 脚本(centos 环境)从 postgresql artifacoty 获取最新版本的 postgresql 版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68507352/
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
ECharts是一个纯Javascript的图表库,可以流畅的运行在PC和移动设备上,兼容当前绝大部分浏览器,底层依赖轻量级的Canvas类库ZRender,提供直观、生动、可交互、可高度个性化定制
前言 提示:这里可以添加本文要记录的大概内容: 例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。 提示:以下是本篇文章正文
作为一名ios开发攻城狮,在苹果没有出arc(自动内存管理机制)时,我们几乎有一半的开发时间都耗费在这么管理内存上.后来苹果很人性的出了arc,虽然在很大程度上,帮助我们开发者节省了精力和时间.但是
如何反转Pandas中DataSeries的排序顺序,以便我按降序使用它们? 最佳答案 In [28]: s = pd.Series([20, 10, 30], ['c', 'a', 'b']) In
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: Is jQuery $.browser Deprecated? 最新的 jQuery 库是否发生变化 $.brows
我正在开发一个 Intranet 项目,所以我无法复制/粘贴代码,所以希望我的描述和一些小片段会有所帮助。 我知道 MySQL 触发器无法做到这一点,但希望有一种干净的 JPA PrePersist(
这是数据集: 人员状态日期 埃里克 1 1/1/2015 埃里克 2 2/1/2015 埃里克 3 2015 年 3 月 1 日 约翰福音 1 3/1/2015 约翰福音 2 2015 年 2 月 1
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
已结束。此问题不符合 Stack Overflow guidelines .它目前不接受答案。 我们不允许提出有关书籍、工具、软件库等方面的建议的问题。您可以编辑问题,以便用事实和引用来回答它。 关闭
现在我正在使用下面的查询按每篇文章的 auto_increment id 排序 mysql_query("SELECT * FROM articles ORDER BY id DESC"); 我想知道
在我们做文章的时候常用一些函数修改来实现自己的页面效果,例如,时间的自定义格式 我们常常需要乃至的,搜集了些有关时间格式的CODE,作大家为参考,希望对大家有些帮助 列表页list_article
我想将某些东西提交到 github 存储库,但我(显然)没有任何权利这样做。我对那个 repo 做了一个分支,提交了我的更改并提交了一个 pull-request。 现在,问题是过了一段时间其他人已经
我是 SQL 新手,所以现有的答案对我来说有点复杂。 我有三张 table : WORKER |id |name |date |... JOB |id |name |salary |accept AP
我正在自动从PowerPoint和Excel电子表格中生成PowerPoint报表。在粘贴表格之前,我已经完成了整个过程。 我使用PPApp.CommandBars.ExecuteMso ("Past
我们有 1 个 Kafka 主题和 1 个分区: 从 spring boot kafka 消费者那里看到一个相当奇怪的行为。 Spring kafka消费者在重新启动时总是从主题的开头开始消费。 我已
通过编程从iOS照片库获取最新照片是否有技巧? 我知道我可以按日期搜索,但是我必须每隔一微秒进行一次扫描,以便进行某种比较以准确地找到它。 有没有人做过这个或任何想法? 最佳答案 我之前采取的一种方法
我们上周将 Web 应用程序中的 Telerik Kendo 库从 V2015.2.902 升级到 V2016.1.112。从那时起,我们注意到使用 Kendo 的页面需要很长时间才能加载(30 秒到
我有两个表: STUDENT GRADES ---------- ---------- id id name person_id ad
我是一名优秀的程序员,十分优秀!