- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望使用 jq
将 JSON 转换为分隔符分隔的扁平化结构。
有人尝试这样做。例如,Flatten nested JSON using jq .
但是,如果 JSON 包含数组,则该页面上的解决方案将失败。例如,如果 JSON 是:
{"a":{"b":[1]},"x":[{"y":2},{"z":3}]}
上面的解决方案将无法将上面的内容转换为:
{"a.b.0":1,"x.0.y":2,"x.1.z":3}
此外,我正在寻找一种还允许使用任意定界符的解决方案。例如,假设空格字符是定界符。在这种情况下,结果将是:
{"a b 0":1,"x 0 y":2,"x 1 z":3}
我希望通过 CentOS 7 中的 Bash (4.2+) 函数访问此功能,如下所示:
flatten_json()
{
local JSONData="$1"
# jq command to flatten $JSONData, putting the result to stdout
jq ... <<<"$JSONData"
}
该解决方案应该适用于所有 JSON 数据类型,包括 null 和 boolean。例如,考虑以下输入:
{"a":{"b":["p q r"]},"w":[{"x":null},{"y":false},{"z":3}]}
它应该产生:
{"a b 0":"p q r","w 0 x":null,"w 1 y":false,"w 2 z":3}
最佳答案
如果您将数据流式传输,您将获得所有叶值的路径和值的配对。如果不是一对,则路径标记该路径处的对象/数组定义的结尾。使用您发现的 leaf_paths
只会为您提供通往真实叶子值的路径,因此您会错过 null
甚至 false
值。作为一个流,你不会遇到这个问题。
有很多方法可以将它组合成一个对象,我偏向于在这些情况下使用 reduce
和赋值。
$ cat input.json
{"a":{"b":["p q r"]},"w":[{"x":null},{"y":false},{"z":3}]}
$ jq --arg delim '.' 'reduce (tostream|select(length==2)) as $i ({};
.[[$i[0][]|tostring]|join($delim)] = $i[1]
)' input.json
{
"a.b.0": "p q r",
"w.0.x": null,
"w.1.y": false,
"w.2.z": 3
}
这里将相同的解决方案分解了一些,以便为解释正在发生的事情留出空间。
$ jq --arg delim '.' 'reduce (tostream|select(length==2)) as $i ({};
[$i[0][]|tostring] as $path_as_strings
| ($path_as_strings|join($delim)) as $key
| $i[1] as $value
| .[$key] = $value
)' input.json
使用 tostream
将输入转换为流,我们将接收多个对/路径值作为我们过滤器的输入。有了这个,我们可以将这些多个值传递到 reduce
中,它旨在接受多个值并用它们做一些事情。但在我们这样做之前,我们希望仅通过对 (select(length==2)
) 过滤这些对/路径。
然后在 reduce 调用中,我们从一个干净的对象开始,并使用从路径派生的键和相应的值分配新值。请记住,reduce
调用中产生的每个值都用于迭代中的下一个值。将值绑定(bind)到变量不会更改当前上下文,赋值会有效地“修改”当前值(初始对象)并将其传递。
$path_as_strings
只是路径,它是字符串和数字到字符串的数组。 [$i[0][]|tostring]
是我用来替代 map
的简写,当我要映射的数组不是当前数组时。这更紧凑,因为映射是作为单个表达式完成的。而不是必须这样做才能获得相同的结果:($i[0]|map(tostring))
。外括号通常可能不是必需的,但它仍然是两个单独的过滤器表达式而不是一个(以及更多文本)。
然后从那里我们使用提供的分隔符将该字符串数组转换为所需的键。然后为当前对象分配适当的值。
关于json - 使用 jq,将任意 JSON 扁平化为分隔符分隔的扁平字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42299905/
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
使用 ListView.separated 我们可以在列表项之间添加 Divider(),但是,一旦我转换到 SliverList,我就看不到我的分隔线了。 delegate: SliverChild
我对 Angular 还很陌生。我有一个由一些数据填充的列表项: {{content.Company}} {{content.Town}}, {{content.P
我正在尝试从 SwiftUI 中的 List 中删除“行”分隔符(在 SwiftUI 中称为分隔符)。 我浏览了 List 文档,但我没能找到它的修饰符。 如有任何帮助,我们将不胜感激。 最佳答案 i
我有一个带有 4 个按钮的网格...1 行 4 列。我正在寻找一种方法将左侧的两个按钮与右侧的两个按钮进行视觉分组。我一直在寻找一种使用分隔符执行此操作的方法,但它似乎与 Grid 一起玩得不好,更喜
我对 R 语言相当陌生。所以我有这个包含以下内容的向量: > head(sampleVector) [1] "| txt01 | 100 | 200 | 123.456
我正在尝试连接两列中的值,当我使用 =CONCAT(A2,",",B2) 时,它将连接两列并获得正确的结果 (P0810,P1)。但我正在寻找的是这样的东西(“P0810”,“P1”)。我尝试了 =C
我在这里创建了一个简单的演示。在 amount 字段编辑时,我想显示 , 分隔符?目前,它仅在不处于编辑模式时显示 ,。知道如何实现这一目标吗? DEMO IN DOJO var data = [{
这里是java菜鸟... 这让我抓狂,因为我知道这很简单,但我已经为此工作了 30 分钟...... 这是来自代码战斗: 对于参数 = ["Code", "Fight", "On", "!"] 且分隔
基于这个pywin32基础script如何向托盘菜单 menu_options 添加分隔符? 我还可以让菜单在左键单击时弹出,而不仅仅是右键单击吗? 最佳答案 将 notify 函数(从 URL 中的
我正在使用这段代码: StringTokenizer tokenizer=new StringTokenizer(line, "::"); 拆分以下字符串: hi my name is visghal
- Dropbox login fix - Updated iris viewer * other aspects are to be improved + fix crash on viewing
我试图在每个菜单组之间显示一个分隔线。我已经尝试过为每个组提供一个唯一的 ID,但这没有用。我找到了一些其他解决方案,但它们看起来有点奇怪,比如创建高度为 1dp 的 LinearLayout。 这是
我想为 CONCAT_WS() 选择一个与字段值不冲突的分隔符例如,如果我选择“,”,则字段值可能包含带有“,”的字符串我想选择一个与字段值不冲突的分隔符:( 最佳答案 来自here : CONCAT
我想知道 Sphinx 引擎是否可以使用任何定界符(如普通 MySQL 中的逗号和句点)。我的问题来自于一种冲动,根本不使用它们,而是逃避它们,或者至少在使用 FULLTEXT 搜索执行 MATCH
我正在尝试使用 svg 或纯 css3 制作 header 分隔符,如下所示: preview from design 在 header 中我有标准的 bootstrap 4 轮播
我在使用 CSS 分隔符时遇到了一些难题。看看:http://jsfiddle.net/fVxC6/1/ .div-line { border-bottom: 1px solid #f0f0f
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 关闭 7 年前。 编辑问题以包含 desired behavior, a specific probl
嘿,我正在尝试使用 getline 读取以下行 (15,0,1,#) (2,11,2,.) (3,20,0,S) 我希望能够将整数提取为 int,将字符提取为 char,但我不知道如何只提取它们。 最
我有 2 列,每边 float 一列,我想使用 1px 宽度的线分隔符,从最长列的顶部到底部。 我宁愿远离 TABLE 布局,而且我不知道哪一个将是最长的列,或者它会有多长。 我怎么能只用 css 做
我是一名优秀的程序员,十分优秀!