gpt4 book ai didi

regex - 我正在尝试使用包含 "awk"的 shell 脚本来针对文件运行

转载 作者:行者123 更新时间:2023-12-04 18:49:16 24 4
gpt4 key购买 nike

read -p "Enter the name for the dealer you are searching for: " dealer
read -p "Enter the time of day you are checking for this dealer: " time
echo "$time $dealer" | awk '/$1/'
所以这就是我到目前为止所拥有的。根据我目前了解到的情况,这会将用户输入的值存储在 dealer 中。和 time .
我接下来要做的是 echo该输入针对一系列命令,以查看文件是否包含这些输入。
例如,轮盘赌庄家“Billy”每隔一天在“05 AM”工作。要查看给定日期的数据是否包含他的工作日志,我将运行此脚本。
./script
运行文件:

Enter the name for the dealer you are searching for: Billy

Enter the time of day you are checking for this dealer: 05


现在这是我正在寻找解决方案的地方。调用脚本时是否对文件运行脚本?我是否让用户输入文件作为第三个参数,然后将其作为脚本内部的值?
如果我学得正确,那么经销商将被存储为 arg1 并由 $1 访问,时间为 $2。
那么我会运行: awk '1$.2$' file ?
这意味着它们之间可以有任何东西,但是如果一行确实包含名称和时间,那么这就是我要搜索的内容。

05:00:00 AM Katey Bean Billy Jones Evalyn Howell


这是我的脚本所需的输出,我知道时间排在第一位,所以我会相应地进行调整,但我正试图更进一步。

最佳答案

从标准输入中读取经销商和时间的输入后,您可以运行 awk使用以下正则表达式:

"^$time.*$dealer"
匹配文件中的行。 (您可能需要对其进行调整以适应您的需求,但作为起点应该就足够了)。
至于文件本身, awk可以从标准输入读取,因此您可以将文件重定向到脚本,如下所示:
./script < data.txt
并运行 awk像这样:
awk -v re="^$time.*$dealer" '$0 ~ re { print $0 }'
这样 awk将从标准输入读取文件内容。
或者,您可以提供文件名作为参数,如下所示:
./script data.txt
并运行 awk像这样:
awk -v re="^$time.*$dealer" '$0 ~ re { print $0 }' "$1"
在哪里 $1是文件名。
您也可以使用对 grep 的等效调用。 (在这种情况下更简洁!):
grep "^$time.*$dealer" "$1"

关于regex - 我正在尝试使用包含 "awk"的 shell 脚本来针对文件运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65485801/

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