Unix工具,用于将文件块减少为字符串--delim =,-pre = [--suf =] <文件

问题描述

我正在寻找一个程序,该程序将字符串与一个char连接起来,添加一个char,然后附加另一个char。 我想我在搜索时使用了错误的关键字,但找不到该问题的理想的Unix工具。

假设我有一个文件(请注意开头的空行):

文件in.txt



{
"some": "json","with_different": "intendation","which": [],"has": 2
}

{
 "json":"objects"
}

生成out.txt

[
{
"some": "json","has": 2
},{
 "json":"objects"
}
]

基本上,我想要一个JSON数组,意思是:

  1. 摆脱掉第一个空行( uniq | tail --lines=+2),
  2. 用逗号(sed -e 's/^$/,g/')和
  3. 替换空行
  4. []awk 'BEGIN {print "["} {print $1} END {print "]"})前面/后面添加

uniq <in.txt | tail --lines=+2 | sed -e 's/^$/,/g' | awk 'BEGIN {print "["} {print $1} END {print "]"}'在给我我想要的东西,但是我敢肯定,这并不优雅。

我找到了pastexargsjoin,但它们对我没有帮助。我也知道OFS中的awk变量,它可以代替sed部分,但是我不知道如何说服awk处理所有“非空”变量。 '以$ 1行(可能使用IFS,但IFS ='^ $'肯定无法正常工作。)然后,我们周围还有另一个样板。

我希望有人可以将我指向magic之类的magic -d"," -s"[" -e"]" <in程序,前提是我已经清理了上面的空白行,或者对象是单线的。

文件in

{"some":"json","which":[],"has": 2}

{ "json":"objects"}

提交out

[
{"some":"json","has": 2},{ "json":"objects"}
]

其他示例是echo "a b c" | magic -d',' -s'[' -e']'返回[a,b,c]

或者,不仅仅举JSON的例子: echo "my new component" | magic -d'-' -s'<' -e'>'返回<my-new-component>

注意:

解决方法

$ awk -v RS= 'BEGIN{sep="[\n"} {printf "%s%s",sep,$0; sep="\n,\n"} END{print "\n]"}' in.txt
[
{
"some": "json","with_different": "intendation","which": [],"has": 2
},{
 "json":"objects"
}
]

$ awk -v RS= 'BEGIN{sep="[\n"} {printf "%s%s",\n"} END{print "\n]"}' in
[
{"some":"json","which":[],"has": 2},{ "json":"objects"}
]
,

使用GNU sed

sed '/./,$!d; s/^/[\n/; :a; n; s/^$/,/; $s/$/\n]/; ba' in.txt

假设输入中没有尾随空白行(前导行被丢弃)。

或者:

sed -n '/./{s/^/[\n/; :a; p; n; s/^$/,/; $s/$/\n]/; ba}' in.txt