0

我有一个 csv 文件,我试图循环遍历该文件,目的是找出是否在 csv 数据中找到了用户输入。我编写了以下代码,有时有效,而其他代码则无效。当我尝试与 2 位以上的数字进行比较时,它总是停止工作。它适用于数字 1 到 9,但一旦你输入让我们说 56 或 99 或 100,它就会停止工作。

csv 数据以逗号分隔,我有大约 300 行,它们就是这样。

1,John Doe,Calculus I,5.0
1,John Doe,Calculus II,4.3
1,John Doe,Physics II,3.5
2,Mary Poppins,Calculus I,3.7
2,Mary Poppins,Calculus II,4.7
2,Mary Poppins,Physics I,3.7

数据就是这样,一直到 ID #100,一共 300 行。sh 文件和 csv 文件都在同一个文件夹中,我使用的是全新安装的 Ubuntu 12.04.3,使用 gedit 作为文本编辑器。

我尝试在 IF 条件中回显变量 ID 和内部,但它在测试相同值时并没有表现出应有的方式。有人可以指出我正确的方向。谢谢

这是代码:

#s!/bin/bash
echo "enter your user ID";
read user;

INPUT_FILE=notas.csv
while IFS="," read r- ID name asignature final;
do
if [$ID = $user]; then
userType=1;
else
userType=2;
fi
done < notas.csv
4

2 回答 2

0

您应该在 if 测试语句中引用您的变量。您还应该执行数字测试-eq而不是字符串比较=。所以你的if陈述应该是这样的:

if [[ "$ID" -eq "$user" ]]
于 2013-11-05T03:34:29.207 回答
0

好吧,您编写的代码有一些问题。

  1. 你有r-而不是-r在线read- 我认为这是你的实际代码中不存在的错字,否则你不会走得太远。

  2. [同样,您需要在...]括号周围留有空格:[$ID是语法错误。

  3. 您需要在if子句中引用参数扩展,和/或切换括号类型。您可能会按照@imp25 的建议将其作为数字比较,我会使用((... ))

  4. 您可能不想userTypeelse子句中设置为 2,因为除了文件中最后列出的人(大概是 ID 100)之外,每个人都会将其设置为 2。您想在循环外首先将其设置为 2。然后,在循环内找到匹配项时,将其设置为 1 并跳出循环:

    userType=2
    while IFS=, read -r ID name asignature final; do
      if (( $ID == $user )); then 
        userType=1;
        break
      fi
    done < notas.csv
    

你也可以只使用 awk 之类的 shell 工具:

userType=$(awk -F, -vtype=2 '($1=="'"$user"'") {type=1}; END {print type}' notas.csv)

grep

grep -q "^$user," notas.csv
userType=$(( $? + 1 ))

等等

于 2013-11-05T03:46:18.413 回答