リストを作成するためのBashスクリプト

リストを作成するためのBashスクリプト

bashフォーマットされたスプレッドシートの列を選択してリストを作成するスクリプトを作成するにはどうすればよいでしょうかcsv?

csv次の内容のファイルがある場合:

        [user]$ cat list1.csv
        Last, First, user
        lname1, fname1, user1
        lname2, fname2, user2

        [user]$ cat list2.csv
        Last, First, user
        lname3, fname3, user3
        lname4, fname4, user4

そしてスクリプトを次のように呼び出したいCreateList <column> <file1> <file2> ...

例えば ​​:

        [user]$ CreateList 2 list2.csv list1.csv
        list2: fname3, fname4
        list1: fname1, fname2

答え1

これはではshありませんbashが、bash実行できます。

$ cat CreateList 
#!/bin/sh

col="$1"; shift

for file
do
        echo -n "$file:"
        cut -d, -f"$col" "$file" | sed 1d | tr '\n' ','| sed '$ s/,$//'
        echo
done

$ 
$ head -9 list*.csv
==> list1.csv <==
Last,First,user
lname1,fname1,user1
lname2,fname2,user2

==> list2.csv <==
Last,First,user
lname3,fname3,user3
lname4,fname4,user4
$ 

$ sh CreateList 2 list2.csv list1.csv
list2.csv:fname3,fname4
list1.csv:fname1,fname2
$ 

答え2

awkを適切に呼び出すだけです

# print first column:
cat list1.csv | awk '{ORS="\t"} {print $1}'

または完全なスクリプトとして:

#!/bin/bash
column=$1
shift;
for item in "$@" ; do
  #process item
  echo "Processing $item:"
  cat $item | awk '{ORS="\t"} {print "'"$column"'"}'
done

役立つ:

https://stackoverflow.com/questions/2021982/awk-印刷なし-改行 https://stackoverflow.com/questions/19075671/awk スクリプトでのシェル変数の使用法

答え3

おそらく最もエレガントな解決策ではありませんが、スペースを含めて指定したとおりの出力が得られます。

#!/bin/bash

function CreateList()
{
  col="$1"
  shift
  cut -d ',' -f $col $@ | sed -r '1d ; s/^[ ]+|[ ]$// ; y/\n/ /; s/[ ]+$/\n/' | xargs echo | sed 's/ /, /'
}

for f in list2.csv list1.csv
do
  echo -n "${f//.csv}: "
  CreateList 2 "$f"
done

出力:

list2: fname3, fname4
list1: fname1, fname2

答え4

単純bash

#!/bin/bash
clm=$(($1 - 1))
shift
for file
do
    printf "%s: " "$file" 
    unset res 
    {
        read
        while IFS=,\  read -a line
        do
            res=(${res[*]} ${line[$clm]}) 
        done
    } <"$file"
    printf "%b, " "${res[@]}"\\n\\c
done

関連情報