服务器上有多个 yml 数据文件,想转换为 HTML 表格文件。原数据不是很复杂,有两列数据,具体如下:
yml 文件内容
date: 1.0.1: http://example.com/1.0.1.tgz 1.0.2: http://example.com/1.0.2.tgz 1.0.3: http://example.com/1.0.3.tgz 1.0.4: http://example.com/1.0.4.tgz 1.0.5: http://example.com/1.0.5.tgz 1.0.6: http://example.com/1.0.6.tgz 1.0.7: http://example.com/1.0.7.tgz 1.0.8: http://example.com/1.0.8.tgz 1.0.9: http://example.com/1.0.9.tgz 1.0.10: http://example.com/1.0.10.tgz
需要转换表格格式,有几个地方需要操作:1. 忽略第一行 date:字符串,2. 剩下的版本号和下载链接分两列,3. 网址添加超链接标签。
<table> <thead> <tr> <th>ver</th> <th>link</th> </tr> </thead> <tbody> <tr> <td>1.0.1</td> <td><a href="http://example.com/1.0.1.tgz">file</a></td> </tr> <tr> <td>1.0.2</td> <td><a href="http://example.com/1.0.2.tgz">file</a></td> </tr> <tr> <td>1.0.3</td> <td><a href="http://example.com/1.0.3.tgz">file</a></td> </tr> <tr> <td>1.0.4</td> <td><a href="http://example.com/1.0.4.tgz">file</a></td> </tr> <tr> <td>1.0.5</td> <td><a href="http://example.com/1.0.5.tgz">file</a></td> </tr> <tr> <td>1.0.6</td> <td><a href="http://example.com/1.0.6.tgz">file</a></td> </tr> <tr> <td>1.0.7</td> <td><a href="http://example.com/1.0.7.tgz">file</a></td> </tr> <tr> <td>1.0.8</td> <td><a href="http://example.com/1.0.8.tgz">file</a></td> </tr> <tr> <td>1.0.9</td> <td><a href="http://example.com/1.0.9.tgz">file</a></td> </tr> <tr> <td>1.0.10</td> <td><a href="http://example.com/1.0.10.tgz">file</a></td> </tr> </tbody> </table>
1
VKMEPR OP 小白没有 shell 基础,网上搜索看了几页结果看得云里雾里,所以请教下各位大佬,任何帮助提前致谢!
|
2
tao14 2019-09-24 22:01:22 +08:00 via Android
awk
|
4
Cooky 2019-09-24 22:13:28 +08:00 via Android
Python 省事
|
5
sker101 2019-09-24 22:17:22 +08:00
1. 为什么要只用 shell
2. 就算找到可用方法大部分都是只是用 shell 跑别人写好的各种 cli 3. 装个可以解 yaml 的语言 nodejs 或 python 甚至 php 自己写个自己操作不好? |
6
EscYezi 2019-09-24 22:17:27 +08:00 via iPad
python+1 现在发行版都自带 python 环境的,直接用 python 吧
|
7
upczww 2019-09-24 22:18:48 +08:00 via Android
用 Python,从第二行开始读,split,把链接读到一个 list 里面,然后构造你要的格式。
|
9
ChristopherWu 2019-09-24 22:19:59 +08:00 1
可以。。太简单了。 关键词:bash read file,awk,echo, >
|
10
ChristopherWu 2019-09-24 22:20:32 +08:00
@VKMEPR #3 你这个问的太伸手党了,没有人会写给你的。
|
11
VKMEPR OP @ChristopherWu 可以付费解决吗?如果可以,麻烦报个价格,也不想做伸手党。。
|
12
ChristopherWu 2019-09-24 22:34:08 +08:00
|
13
aheadlead 2019-09-24 22:42:24 +08:00
算了 我来写一个吧
|
14
aheadlead 2019-09-24 22:47:36 +08:00
|
15
ant2017 2019-09-24 22:54:54 +08:00
awk -F ': ' '$2 ~ /tgz$/ {print "<tr>\n<td>"$1"</td>\n<td><a href=\""$2"\">file</a></td>\n</tr>"}' filename
|
16
5long 2019-09-24 23:05:21 +08:00 1
解析结构化的数据,建议用能正确解析这种格式的库,不建议用取巧的办法。在这个例子里要解析 YAML,那么就找个能解析 YAML 的库。比如用 Python 装上 pyyaml https://pyyaml.org/ ,或者用 Ruby 标准库里的 yaml https://ruby-doc.org/stdlib-2.6.4/libdoc/yaml/rdoc/index.html
至于说输出 HTML 的步骤,用模板语言或者自己拼字符串,都随意了。 |
17
defunct9 2019-09-25 01:29:23 +08:00 via iPhone
yq
|
18
ysc3839 2019-09-25 01:33:16 +08:00 via Android 1
这样的数据让我选的话我还是选择用 Python 写。
|
19
downdowndown30 2019-09-25 01:41:29 +08:00 via Android
@ChristopherWu 下面好多人给了😂
|
20
UnknownR 2019-09-25 02:06:16 +08:00
像 python,powershell 这种都有对应的库,比如直接导入成 yml 数据类型,然后转换成容易修改、读取的格式,比如 object,再选取想要的 value 和 name 用对应的库转换成 html。或者你就强行用 awk 或者其他脚本语言的 split 参数把想要的数据分离出来
|
21
oneisall8955 2019-09-25 06:43:19 +08:00 via Android
略简单,正则匹配,分 2 组完事了
|
22
Nitroethane 2019-09-25 07:37:26 +08:00 via Android
用 Python 解析出来后根据自己的需求拼接 markdown 字符串,然后渲染成 HTML
|
23
msg7086 2019-09-25 08:00:23 +08:00 via Android
想起我司傻逼代码用 shell 调 awk 解析 XML。
特别想打死那个写代码的人。 |
26
VKMEPR OP @ChristopherWu 感谢建议!会结合大佬们给建议和示例去理解用法
|
27
OceanSea 2019-10-03 11:03:51 +08:00
vim 都可以 录制宏
|