- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果您有这样的csv数据集:
name, age, gender
john, 20, male
jane, 30, female
bob, 25, male
你能做到这一点:
[ {"name": "john", "age": 20, "gender": "male"},
{"name": "jane", "age": 30, "gender": "female"},
{"name": "bob", "age": 25, "gender": "male"} ]
仅使用jq?
最佳答案
简而言之-是的,除了单线的。
jq通常非常适合文本拼写,对于具有正则表达式支持的版本尤其如此。例如,使用正则表达式支持,给定问题语句所需的修整是微不足道的。
由于jq 1.5rc1包含正则表达式支持,并且自2015年1月1日起可用,因此以下程序假定使用jq 1.5版本。如果要使其与jq 1.4一起使用,请参阅两个“对于jq 1.4”注释。
另请注意,该程序不能全面处理CSV。 (有关更通用地处理CSV的类似方法,请参见https://github.com/stedolan/jq/wiki/Cookbook#convert-a-csv-file-with-headers-to-json)
# objectify/1 takes an array of string values as inputs, converts
# numeric values to numbers, and packages the results into an object
# with keys specified by the "headers" array
def objectify(headers):
# For jq 1.4, replace the following line by: def tonumberq: .;
def tonumberq: tonumber? // .;
. as $in
| reduce range(0; headers|length) as $i ({}; .[headers[$i]] = ($in[$i] | tonumberq) );
def csv2table:
# For jq 1.4, replace the following line by: def trim: .;
def trim: sub("^ +";"") | sub(" +$";"");
split("\n") | map( split(",") | map(trim) );
def csv2json:
csv2table
| .[0] as $headers
| reduce (.[1:][] | select(length > 0) ) as $row
( []; . + [ $row|objectify($headers) ]);
csv2json
$ jq -R -s -f csv2json.jq csv.csv
[
{
"name": "john",
"age": 20,
"gender": "male"
},
{
"name": "jane",
"age": 30,
"gender": "female"
},
{
"name": "bob",
"age": 25,
"gender": "male"
}
]
关于json - 使用jq将CSV转换为JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29663187/
我在数组中有一系列 [timestamp, count] 对,我想使用 jq 计算每个时间戳的累积和。我怎么能那样做? 这里是一个示例数据集: [ [1431047957699, 1], [1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我在数组中有一系列 [timestamp, count] 对,我想使用 jq 计算每个时间戳的累积和。我怎么能那样做? 这里是一个示例数据集: [ [1431047957699, 1], [1
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我很好奇是否有一种干净的方法可以将行号添加到 jq 的输出,同时仍然保留输出的颜色。我已经尝试从 jq 到 cat -n 的管道,但不幸的是,这删除了在遍历 JSON 树时有很大帮助的着色。 最佳答案
我有一些看起来像json数据: { "p": { "d": { "a" : { "r": "foo", "g": 1 },
我正在使用 jq 在大文件中搜索特定结果。我不关心与此特定条件匹配的重复条目,并且处理整个文件需要一段时间。我想做的是打印有关第一场比赛的一些详细信息,然后在文件上终止 jq 命令以节省时间。 IE。
给定以下 JSON 文件 foo.js(为清楚起见已删除): {"a":{"b":[{"x":{"x1":1},"y":{"y1":5}},{"x":{"x1":1},"y":{"y1":6}}]}}
我需要从一些 JSON 中一次删除多个键(使用 jq ),并且我正在尝试了解是否有比每次调用 map 和 del 更好的方法。这是我的输入数据: test.json [ { "label"
我正在使用 jq 来解析日志数据,偶尔日志包含格式错误的内容(无效的 json),当发生这种情况时,jq 会在此时中止处理。 有没有办法让 jq 继续处理它可以做的事情,同时通过 stderr 报告问
我无法理解以下示例中显示的 jq(版本 1.6)更新运算符的行为。 为什么示例 1 返回更新后的对象,而示例 2 和 3 返回空对象或错误结果? 例子之间的区别仅在于将字符串转换为数字的函数的调用顺序
给定 [3,4] [5,2] 我想制作: [5,2] [3,4] 我试过了,但失败了: echo '[3,4] [5,2]' | jq 'sort_by(.[1])' jq: error (at :1
我有一个要用 JQ 处理的 JSON 文件。它在另一个对象中有一个对象数组,带有一个我想用来填充新数组的键。 在我的实际用例中,它嵌套在许多其他的绒毛中,还有更多的数组,但将其作为此类事物的一个更简单
我有这个 jq筛选: some_command | jq -r '.elements[] | select(.state=="LIVE" and .group == "some_text" and .
我无法理解以下示例中显示的 jq(版本 1.6)更新运算符的行为。 为什么示例 1 返回更新后的对象,而示例 2 和 3 返回空对象或错误结果? 例子之间的区别仅在于将字符串转换为数字的函数的调用顺序
给定 [3,4] [5,2] 我想制作: [5,2] [3,4] 我试过了,但失败了: echo '[3,4] [5,2]' | jq 'sort_by(.[1])' jq: error (at :1
我刚刚发现 jq 并且非常喜欢它。一件事我发现自己做了很多事情,比如: result=$(jq --raw-output '.some | .filters // ""') if [[ $result
我一直在尝试使用 chocoletey 安装 jq 但是,当我运行以下命令时,它失败了。 choco install jq 阅读日志文件,我看到它指向 Powershell 脚本指向一个不再存在的 U
json block 数组中的数千个 json block 之一如下所示 - { "id": 4409976, "name": "MKLIU", "version": "1.0", "
json block 数组中的数千个 json block 之一如下所示 - { "id": 4409976, "name": "MKLIU", "version": "1.0", "
我是一名优秀的程序员,十分优秀!