Определить следующее имя для конкретного файла [закрыто]

Мне нужно создать сценарий, который берет мой _Release $ META $ PROJECT

здесь META = red , PROJECT = green

Затем мне нужно определить название следующего выпуска для этого META и PROJECT для вашего пользователя

, например: / user / desktop / release / red / green / file_2 следующим должно быть / user / desktop / release / red / green / file_3

Итак, представьте, что в этой папке много файлов, поэтому мне нужно определить который является самым высоким, и увеличьте его. Я думаю, стоит ли мне сначала поискать во всех папках, я действительно запутался.

2
задан 26 June 2017 в 23:32

2 ответа

Мое решение состоит в том, чтобы изучить тот каталог для файлов и затем выбрать последний:

filename=`find . | sort -t_ -k2 -n | tail -1`

затем показывают имя нового файла:

echo ${filename%_*}_$(( ${filename##*_} + 1 ))

позволяют нам протестировать его:

$ mkdir test
$ cd test
$ touch file_{1..999}
$ filename=`find . | sort | tail -1`
$ echo $filename
./file_999

Получают имя файла:

$ echo ${filename%_*}
./file

Получают номер +1:

$ echo $(( ${filename##*_} + 1 ))
1000

Объединяют их:

$ echo ${filename%_*}_$(( ${filename##*_} + 1 ))
./file_1000
2
ответ дан 2 December 2019 в 03:39

Чистый Bash

get_next_release_name()(
    filename_base='file_'

    # Create array with indices based on the filenames.
    for filename in *; do
        index="${filename##$filename_base}"
        filenames["$index"]="$filename"
    done

    # Get last item in array and get its index.
    filename_highest="${filenames[-1]}"
    index_highest="${filename_highest##*_$filename_base}"

    # Get highest index + 1.
    index_new_highest="$(( $index_highest + 1 ))"
    filename_new="${filename_base}${index_new_highest}"

    echo "$filename_new"
)

Тест:

# Create test files.
$ mkdir test &&
>  cd test
$ touch file_{1..999}
$ get_next_release_name
file_1000

Также вот эквивалент в Python, если Вы хотите его. Я главным образом хотел попробовать его и видеть, насколько легче это будет. Оказывается, что это почти так же легко, но намного более просто (например, меньше работы для получения самого высокого индекса).

import os

filename_base = 'file_'

indices = []
for filename in os.listdir('.'):
  index = int(filename.split(filename_base)[1])
  indices += [ index ]

index_highest = max(indices)
index_new_highest = index_highest + 1
new_filename = filename_base + str(index_new_highest)

print new_filename

Также менее подробная версия:

import os

f_base = 'file_'
indices = [ int(f.split(f_base)[1]) for f in os.listdir('.') ]
print f_base + str(max(indices) + 1)
0
ответ дан 2 December 2019 в 03:39

Другие вопросы по тегам:

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