web-dev-qa-db-ja.com

すべての端末出力をファイルに保存します

コマンドですべての端末出力をファイルに保存する方法はありますか?

  • リダイレクトについて話しているのではありませんcommand > file.txt
  • 歴史ではないhistory > file.txt、完全な端末テキストが必要です
  • ホットキーではありません!

何かのようなもの terminal_text > file.txt

66
rsm

scriptを使用できます。基本的には、そのscriptセッションでターミナルに出力されたすべてのものを保存します。

から man script

script makes a TypeScript of everything printed on your terminal. 
It is useful for students who need a hardcopy record of an 
interactive session as proof of an assignment, as the TypeScript file 
can be printed out later with lpr(1).

ターミナルでscriptと入力するだけでscriptセッションを開始できます。後続のすべてのコマンドとその出力はすべて、現在のディレクトリのTypeScriptという名前のファイルに保存されます。次のようにscriptを開始するだけで、結果を別のファイルに保存することもできます。

script output.txt

screenセッションからログアウト(内容の保存を停止)するには、「exit」と入力します。

次に例を示します。

$ script output.txt
Script started, file is output.txt

$ ls
output.txt  testfile.txt  foo.txt

$ exit
exit
Script done, file is output.txt

ファイルを読んだ場合:

$ cat output.txt

Script started on Mon 20 Apr 2015 08:00:14 AM BDT
$ ls
output.txt  testfile.txt  foo.txt
$ exit
exit

Script done on Mon 20 Apr 2015 08:00:21 AM BDT

scriptには多くのオプションもあります。静かに走る-q--quiet)プログラムメッセージを表示/保存せずに、特定のコマンドを実行することもできます-c--command)セッションではなく、他にも多くのオプションがあります。小切手 - man script より多くのアイデアを得るために。

79
heemayl

私も同じ問題に直面し、いくつかの検索がこの解決策を思いついた後:

これを.bash_aliasesに追加します。

# Execute "script" command just once
smart_script(){
    # if there's no SCRIPT_LOG_FILE exported yet
    if [ -z "$SCRIPT_LOG_FILE" ]; then
        # make folder paths
        logdirparent=~/Terminal_typescripts
        logdirraw=raw/$(date +%F)
        logdir=$logdirparent/$logdirraw
        logfile=$logdir/$(date +%F_%T).$$.rawlog

        # if no folder exist - make one
        if [ ! -d $logdir ]; then
            mkdir -p $logdir
        fi

        export SCRIPT_LOG_FILE=$logfile
        export SCRIPT_LOG_PARENT_FOLDER=$logdirparent

        # quiet output if no args are passed
        if [ ! -z "$1" ]; then
            script -f $logfile
        else
            script -f -q $logfile
        fi

        exit
    fi
}

# Start logging into new file
alias startnewlog='unset SCRIPT_LOG_FILE && smart_script -v'

# Manually saves current log file: $ savelog logname
savelog(){
    # make folder path
    manualdir=$SCRIPT_LOG_PARENT_FOLDER/manual
    # if no folder exists - make one
    if [ ! -d $manualdir ]; then
        mkdir -p $manualdir
    fi
    # make log name
    logname=${SCRIPT_LOG_FILE##*/}
    logname=${logname%.*}
    # add user logname if passed as argument
    if [ ! -z $1 ]; then
        logname=$logname'_'$1
    fi
    # make filepaths
    txtfile=$manualdir/$logname'.txt'
    rawfile=$manualdir/$logname'.rawlog'
    # make .rawlog readable and save it to .txt file
    cat $SCRIPT_LOG_FILE | Perl -pe 's/\e([^\[\]]|\[.*?[a-zA-Z]|\].*?\a)//g' | col -b > $txtfile
    # copy corresponding .rawfile
    cp $SCRIPT_LOG_FILE $rawfile
    printf 'Saved logs:\n    '$txtfile'\n    '$rawfile'\n'
}

そして.bashrcファイルの最後にこれを追加してください:

smart_script

これを実行すると、「script」コマンドがすべてのターミナルセッションで1回実行され、すべてのログが「〜/ Terminal_typescripts/raw」に記録されます。必要に応じて、現在のセッションログを保存できます事後(セッションの最後)「savelog」または「savelog logname」と入力すると、現在の生ログが「〜/ Terminal_typescripts/manual」にコピーされ、このフォルダに読み取り可能な.txtログが作成されます。 (そうするのを忘れた場合でも、生のログファイルはフォルダーに残ります。それらを見つける必要があります。)また、「startnewlog」と入力して、新しいログファイルへの記録を開始することもできます。

ジャンクログファイルはたくさんありますが、古いファイルはときどきクリーニングできるので、大きな問題ではありません。

https://answers.launchpad.net/ubuntu/+source/gnome-terminal/+question/7131 に基づく https://askubuntu.com/a/493326/ 47379

13
alexpad

すでに述べたように、セッションのテキストを保存することが事前にわかっている場合は、scriptを使用できます。また、ターミナル出力をコピーしてテキストエディターに貼り付けると、私が信じているトリックを実行しているようです。

1
ChrisGS