Внутри bash-скрипта я динамически загружаю файл, и поэтому я использую wget --content-disposition чтобы убедиться, что имена файлов правильные, но как мне получить имя файла, wget сохранила его как?
1 ответ
Вот способ сделать это с помощью wget и cut:
wget -nv https://upload.wikimedia.org/wikipedia/commons/5/54/Golden_Gate_Bridge_0002.jpg 2>&1 |cut -d\" -f2
Пояснение, wget -nv ... выводит что-то вроде этого:
2016-11-15 14:58:44 URL:https://upload.wikimedia.org/wikipedia/commons/5/54/Golden_Gate_Bridge_0002.jpg [1072554/1072554] -> "Golden_Gate_Bridge_0002.jpg.22" [1]
Флаг -nv на wget делает его «не многословным» (см .: man wget)
Поскольку wget записывает свой вывод в STDERR мы должны перенаправить его в STDOUT прежде чем мы сможем извлечь текст; для этого мы добавляем 2>& в конце wget . Затем, чтобы получить только имя файла в конце, я использовал cut . -d\" указывает, что мы используем " в качестве разделителя. -f2 указывает, что нам нужен второй "столбец", т. Е. Данные между первым и вторым разделителями " .
Первый столбец: 2016-11-15 14:58:48 URL:https://upload.wikimedia.org/wikipedia/commons/5/54/Golden_Gate_Bridge_0002.jpg [1072554/1072554] -> " Golden_Gate_Bridge_0002.jpg.23` "[1]
