繁体   English   中英

如何从脚本创建简单的日志文件

[英]How To Create Simple Log File From Script

我正在尝试创建一个名为“users.txt”的简单日志文件,其中包含输入的用户名、全名和主目录。 我还想包括脚本最初运行的时间。

有什么建议?

脚本名称叫做 catbash.sh

我尝试过诸如 catbash.sh > user.txt 之类的东西

但我不知道如何获取特定信息等。

clear
LOGFILE=/home/student/gg193/FileTypes/TextFiles/ShellScripts/user.txt

read -p "What is your username?" username
read -p "May I know your name please? " name surname

echo "$(date) $username $name $surname $LOGFILE" >> $LOGFILE

TIME=$(date "+%H")

if [ $TIME -ge 0 -a $TIME -lt 12 ]
then
        echo "\nGood Morning, $surname"
elif [ $TIME -ge 12 -a $TIME -lt 18 ] 
then
        echo "\nGood afternoon $surname"
else 
        echo "\nGood evening $surname"
fi

echo "1. nonblank\n2. number\n3. ends\n4. nends\n"

while : 
do
    read INPUT_STRING
    case $INPUT_STRING in

        nonblank)
            NonEmptyLine=$(cat catbash.sh | sed '/^\s*$/d' | wc -l)
            echo "\nNumber of Non-Empty Lines are:" $NonEmptyLine
            break
            ;;
        number)
            EmptyLine=$(grep -cvP '\S' catbash.sh)
            echo "\nNumber of Empty Lines are:" $EmptyLine
            break
            ;;
        ends)
            echo "================================================================================="
            sed 's/$/$/' catbash.sh
            echo "================================================================================="
            break
            ;;
        nends)
            NonEmptyLine=$(cat catbash.sh | sed '/^\s*$/d' | wc -l)
                        echo "\nNumber of Non-Empty Lines are:" $NonEmptyLine
            EmptyLine=$(grep -cvP '\S' catbash.sh)
                        echo "\nNumber of Empty Lines are:" $EmptyLine
            echo "================================================================================="
            sed 's/$/$/' catbash.sh
            echo "================================================================================="
            break
            ;;
        *)
            echo "\nSorry, I don't understand"
            ;;
    esac
done

DURATION=$(ps -o etime= -p "$$")
echo "\nAmount of time that has passed since the script was initially executed:" $DURATION

echo "\nThanks for using catbash.sh!"

您必须从 sh 脚本内部进行日志记录。 例如,您可以在终端上echo显您想要的信息(您已经在做),然后附加| tee -a $LOGFILE | tee -a $LOGFILE (在顶部定义 LOGFILE,因此如果您需要不同的文件名/位置,则只需更改一次)。

作为进一步的改进,您可以考虑定义自己的记录器功能,甚至探索现有的记录器功能。 例如,一个更简单的记录器 func 可能需要 2 个参数 - 消息、文件名。 消息本身可以根据需要由用户名、日期/时间戳等组成。

根据您问题中当前的信息,这是我能给出的最佳指示。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM