Сценарий Bash. Секунды сдвига

Символьные ссылки являются по существу просто указателями на другой файл, Вы не можете указать на что-то вне chroot, потому что он ищет файл с тем именем (/var/www, который не существует в chroot). Hardlinks, с другой стороны, являются указателями на inode. По сути, если Вы хотите сделать это, необходимо использовать жесткую ссылку путем исключения -s. Однако Вы не можете жесткая ссылка каталог (кроме . и ..) в Linux по ряду причин (основной, являющийся, что те файловые системы являются DAG).

Возможно, лучший способ состоял бы в том, чтобы использовать связывание, монтируются. Попробуйте это:

mount --bind /var/www /home/username/www

6
18.11.2018, 21:19
2 ответа

Если файл подзаголовка не охватывает больше чем 24 часа, можно использовать date для этого:

#!/usr/bin/env bash

set -o errexit -o noclobber -o nounset -o pipefail

date_offset="$1"

shift_date() {
    date --date="$1 $date_offset" +%T,%N | cut -c 1-12
}

while read -r line
do
    if [[ $line =~ ^[0-9][0-9]:[0-9][0-9]:[0-9][0-9],[0-9][0-9][0-9]\ --\>\ [0-9][0-9]:[0-9][0-9]:[0-9][0-9],[0-9][0-9][0-9]$ ]]
    then
        read -r start_date separator end_date <<<"$line"
        new_start_date="$(shift_date "$start_date")"
        new_end_date="$(shift_date "$end_date")"
        printf "%s %s %s\n" "$new_start_date" "$separator" "$new_end_date"
        echo "New date"
    else
        printf "%s\n" "$line"
    fi
done

По некоторым причинам необходимо использовать десятичные числа с этим, но это работает:

$ ./shifter.sh "+3.0 seconds" < bmt.srt
5
00:01:05,323 --> 00:01:08,572
New date
Hello, my frieds!
6
7
27.01.2020, 20:23

Решение для Perl. Я не использовал модуля обработки абсолютного времени, поскольку обработка миллисекунд обычно плохо поддерживается.

#!/usr/bin/perl
use warnings;
use strict;

use constant FACTORS => (60 * 60 * 1000,
                              60 * 1000,
                                   1000,
                                      1);

sub time2ms {
    my $time = shift;
    my ($ms, $i) = (0, 0);
    $ms += (FACTORS)[$i++] * $_ for split /[^0-9]/, $time;
    return $ms;
}


sub ms2time {
    my $ms = shift;
    my $str = q();
    for my $i (0 .. 3) {
                $str .= sprintf +($i == 3 ? '%03d' : '%02d')
                                    . (':', ':', ',', q())[$i],
                                $ms / (FACTORS)[$i];
        $ms = $ms % (FACTORS)[$i];
    }
    return $str;
}


my $diff   = 1000 * shift;
my $TIME_R = qr/[0-9]{2}:[0-9]{2}:[0-9]{2},[0-9]{3}/;
while (<>) {
    if (my ($from, $to) = /($TIME_R) --> ($TIME_R)/) {
        my $i = 0;
        for my $time ($from, $to) {
            $time = time2ms($time) + $diff;
            print ms2time($time), (' --> ', "\n")[$i++];
        }
    } else {
        print;
    }
}
5
27.01.2020, 20:23
  • 1
    Спасибо за сценарий! Позвольте мне добавить маленькое улучшение хотя: В ms2time цикле, если $i == 3, sprintf должен быть '%03d' вместо '%02d'. –  Vangelis Tasoulas 06.01.2014, 22:07
  • 2
    @VangelisTasoulas: Обновленный. большое спасибо –  choroba 12.02.2017, 19:11

Теги

Похожие вопросы