gpt4 book ai didi

linux - CSV Bash 循环变量问题

转载 作者:太空宇宙 更新时间:2023-11-04 04:09:40 24 4
gpt4 key购买 nike

我有一个 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

最佳答案

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

  1. 您在 read 行上使用了 r- 而不是 -r - 我认为这是实际代码中不存在的拼写错误,否则您不会走得太远。

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

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

  4. 您可能不想在 else 子句中将 userType 设置为 2,因为这会将每个人的值设置为 2,除了文件中最后列出的人员(大概是 ID 100)之外。您想首先在循环之外将其设置为 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 ))

等等

关于linux - CSV Bash 循环变量问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19781214/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com