Вывести вывод кода в середину экрана


10

Код ниже будет выводить все, что fileслово в слово на экране. Например:

Hello будет отображаться в течение 1 секунды и исчезнет. Затем следующее слово в предложении появится на секунду и исчезнет, ​​и так далее.

Как вывести то, что отображается в середине экрана?

awk '{i=1; while(i<=NF){ print $((i++)); system("sleep 1; clear") }}' file

Чего именно вы пытаетесь достичь?
Муру

эта команда отображает каждое слово из файла в верхнем левом углу экрана. Мне нужно знать, как сделать вывод в середине экрана.
Nebelz Cheez

4
Да, но чего вы пытаетесь достичь? Это звучит как проблема XY ,
Muru

Что такое "середина экрана"? Середина терминала? Середина реального экрана? Что если вы измените размер терминала, вам нужно это для динамического размещения текста в середине, независимо от размера вашего терминала?
тердон

да. Середина терминала.
Nebelz Cheez

Ответы:


7

Вот вам очень надежный скрипт bash:

#!/bin/bash

## When the program is interrupted, call the cleanup function
trap "cleanup; exit" SIGHUP SIGINT SIGTERM

## Check if file exists
[ -f "$1" ] || { echo "File not found!"; exit; }

function cleanup() {
    ## Restores the screen content
    tput rmcup

    ## Makes the cursor visible again
    tput cvvis
}

## Saves the screen contents
tput smcup

## Loop over all words
while read line
do
    ## Gets terminal width and height
    height=$(tput lines)
    width=$(tput cols)

    ## Gets the length of the current word
    line_length=${#line}

    ## Clears the screen
    clear

    ## Puts the cursor on the middle of the terminal (a bit more to the left, to center the word)
    tput cup "$((height/2))" "$((($width-$line_length)/2))"

    ## Hides the cursor
    tput civis

    ## Prints the word
    printf "$line"

    ## Sleeps one second
    sleep 1

## Passes the words separated by a newline to the loop
done < <(tr ' ' '\n' < "$1")

## When the program ends, call the cleanup function
cleanup

8

Попробуйте скрипт ниже. Он будет определять размер терминала для каждого входного слова, поэтому даже будет динамически обновляться, если вы измените размер терминала во время его работы.

#!/usr/bin/env bash

## Change the input file to have one word per line
tr ' ' '\n' < "$1" | 
## Read each word
while read word
do
    ## Get the terminal's dimensions
    height=$(tput lines)
    width=$(tput cols)
    ## Clear the terminal
    clear

    ## Set the cursor to the middle of the terminal
    tput cup "$((height/2))" "$((width/2))"

    ## Print the word. I add a newline just to avoid the blinking cursor
    printf "%s\n" "$word"
    sleep 1
done 

Сохраните его как ~/bin/foo.sh, сделайте его исполняемым ( chmod a+x ~/bin/foo.sh) и укажите в качестве первого аргумента входной файл:

foo.sh file

3

функция Bash, чтобы сделать то же самое

mpt() { 
   clear ; 
   w=$(( `tput cols ` / 2 ));  
   h=$(( `tput lines` / 2 )); 
   tput cup $h;
   printf "%${w}s \n"  "$1"; tput cup $h;
   sleep 1;
   clear;  
}

а потом

mpt "Text to show"

1
Это похоже на мой ответ, за исключением того, что он показывает одну вещь, а не каждое слово предложения, прочитанное из файла отдельно, как того требует ОП.
тердон

1

Вот Python скрипт , который похож на @ Helio в bashрастворе :

#!/usr/bin/env python
import fileinput
import signal
import sys
import time
from blessings import Terminal # $ pip install blessings

def signal_handler(*args):
    raise SystemExit

for signal_name in "SIGHUP SIGINT SIGTERM".split():
    signal.signal(getattr(signal, signal_name), signal_handler)

term = Terminal()
with term.hidden_cursor(), term.fullscreen():
    for line in fileinput.input(): # read from files on the command-line and/or stdin
        for word in line.split(): # whitespace-separated words
            # use up to date width/height (SIGWINCH support)
            with term.location((term.width - len(word)) // 2, term.height // 2):
                print(term.bold_white_on_black(word))
                time.sleep(1)
                print(term.clear)
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.