使用每行的用户输入替换文件中的某个字段并保存在同一文件中

时间:2016-02-29 09:36:27

标签: linux bash awk sh gawk

我打字写一个可以读 file_name 分隔符 field_number 的脚本。之后为每一行取一个输入,替换字段(由 field_number 指定)并输出到同一文件。

例如,如果输入如下:

Ritesh;M;1992
Shakya;F;1993

对于命令

bash_script.sh test.csv ";" 3

如果我输入 1994 作为第一行并且1995年作为第二行输入,则遍历每一行。我希望输出在同一个文件中如下陷阱。

Ritesh;M;1994
Shakya;F;1995

到目前为止,我设法达到了这一点:

#!/usr/bin/env bash
echo "Following is the input needed:";
echo "\$1: FILE_NAME";
echo "\$2: DELIMITER";
echo "\$3: FIELD IN NUMERIC VALUE";

gawk -i inplace -F "$2" '{...}' $1;

我的gawk版本也不支持-i。 提前谢谢。

2 个答案:

答案 0 :(得分:0)

使用sed总是我选择退出;

#!/bin/bash
FILE=$1
DELIM=$2
FIELD=$3

REPLACEMENT="XXX"
sed "s/[^$DELIM]*/$REPLACEMENT/$FIELD" $FILE

如果它需要是根据当前值计算的东西,则需要循环每一行并将其解压缩。

#!/bin/bash
FILE=$1
DELIM=$2
FIELD=$3

while read line; do
   value="$(echo $line | cut -d"$DELIM" -f$FIELD)"
   if [ "$value" == "1992" ]; then REPLACEMENT="1994";
   elif [ "$value" == "1993" ]; then REPLACEMENT="1995";
   fi
   echo $line | sed "s/[^$DELIM]*/$REPLACEMENT/$FIELD"
done < $FILE

答案 1 :(得分:0)

回答第一个问题

如果您只需要将1992替换为1994而将1993替换为1995,则不需要脚本,您可以使用sed轻松完成:< / p>

sed "s/;1992/;1994/g" test.csv | sed "s/;1993/;1995/g" 

输出:

[shell] ➤ sed "s/;1992/;1994/g" test.csv | sed "s/;1993/;1995/g"
Ritesh;M;1994
Shakya;F;1995

如果您还需要保存输出,可以添加

sed "s/;1992/;1994/g" test.csv | sed "s/;1993/;1995/g" > temp; mv temp test.scv 

但是如果你想使用一个脚本:

#!/bin/bash

if [ -z "${1}" ];then
        echo "Usage: $0 <filename>"
else
        FILENAME=$1
        sed "s/;1992/;1994/g" $FILENAME| sed "s/;1993/;1995/g"
fi

输出:

[shell] ➤ ./test3.sh
Usage: ./test3.sh <filename>

[shell] ➤ ./test3.sh test.csv
Ritesh;M;1994
Shakya;F;1995

在上次评论后更新了脚本

#!/bin/bash
if [ -z "${3}" ];then
        echo "Usage: <filename> <delimiter> <field_no>"
else
        FILENAME=$(readlink -f $1)
        DELIMITER=$2
        FIELD_NO=$3
        TEMP_FILE=/tmp/tempFile
        if [ -f $TEMP_FILE ]; then
            rm $TEMP_FILE
        fi
        for line in $(cat $FILENAME)
        do
                oldValue=`echo $line|cut -d$DELIMITER -f$FIELD_NO`
                echo "Enter the value to replace [$oldValue]"
                read newValue
                echo $line | sed "s/${oldValue}/${newValue}/g" >> $TEMP_FILE
        done
fi
mv $TEMP_FILE $FILENAME    

我评论了命令#mv tempFile $FILENAME,因为您可以选择重命名文件或保留新文件。