将具有不同标题的文本文件重新排列为 csv

将具有不同标题的文本文件重新排列为 csv

我在 Linux 机器上有一个这样的文件:

dn: cn=333-MMMM-PPPP_DET1,ou=groups,ou=functional,o=company
member: cn=aaa,ou=users,ou=accounts,o=company
member: cn=bbb,ou=users,ou=accounts,o=company
member: cn=ccc,ou=users,ou=accounts,o=company
member: cn=ddd,ou=users,ou=accounts,o=company
member: cn=eee,ou=users,ou=accounts,o=company

dn: cn=333-MMMM-PPPP_DET2,ou=groups,ou=functional,o=company

dn: cn=333-MMMM-PPPP_DET3,ou=groups,ou=functional,o=company
member: cn=aaa,ou=users,ou=accounts,o=company
member: cn=ggg,ou=users,ou=accounts,o=company
 

我想将其转换为一个简单格式的 csv,以便在进一步的应用程序中导入:

aaa;333-MMMM-PPPP_DET1 
bbb;333-MMMM-PPPP_DET1
ccc;333-MMMM-PPPP_DET1
ddd;333-MMMM-PPPP_DET1
eee;333-MMMM-PPPP_DET1
aaa;333-MMMM-PPPP_DET3
ggg;333-MMMM-PPPP_DET3

我已经尝试过: awk '1;/^$/{exit}-> 显示所有行,直到第一次中断(计划是打印它们,将其移动到另一个文件,然后删除它们。在一个循环中。 awk 'FNR == 1 {suffix=$0} {print $0suffix}'-> 取出第一行并将其放在所有其他行的末尾线。

我没有找到解决这个问题的方法。有什么建议么?

答案1

$ awk -F'[,=]' -v OFS=',' '/^dn/{dn=$2} /^me/{print $2, dn}' file
aaa,333-MMMM-PPPP_DET1
bbb,333-MMMM-PPPP_DET1
ccc,333-MMMM-PPPP_DET1
ddd,333-MMMM-PPPP_DET1
eee,333-MMMM-PPPP_DET1
aaa,333-MMMM-PPPP_DET3
ggg,333-MMMM-PPPP_DET3

相关内容