425675
Number: -5
Name: BBB
ID: 191000
Number: -40
Name: CCC
ID: 200111
Number: -12
Name: DDD
ID: 100200
Пытаюсь отформатировать его к виду:
Number Name ID
-5 BBB 191000
-10 AAA 425675
-12 DDD 100200
-40 CCC 200111
В файле повторяются одни и те же строки в виде "ключ-значение". Возможно, стоит его разбить на части, например на хэши или массивы и работать с каждым хэшом или массивом по отдельности, но тут возникает трудность с сортировкой разных хэшей (или массивов) по одному полю - Number (когда сортируем числа в одном массиве или хэше все просто, но тут немного сложнее).
Подскажите, пожалуйста, как правильнее решать такую задачу?
Все сложить в один хеш, отсортировать по значению ключа Number в обратном порядке как числа, сложить результат в выходной файл 🤷♂ Или просто построчный дамп в файл, потом sort -nrk 1
cat test | paste - - - | sort -nk2 | sed '...'
Вот сложили мы содержимое файла в один хэш (допустим). Как привязать значение Number к Name, ID в рамках него?
А понял, Name, ID будут значениями.
Хэш хэшей сделай и все
Можно попробовать. У меня возникают сложности с разделением содержимого файла на части, т.е. на отдельные Number, Name, ID. Есть ли в Perl инструменты для определения какой по счету match или в какой строке файла по номеру match?
Если у тебя структура файла жёстко задана и все поля всегда присутствуют, то тебе досточно просто дёргать три строки подряд, и их складывать в структуру
Попробую так. Спасибо!
Если структура задана не жестко, тогда надо понимать, как отличить одну запись от другой. И тогда уже проще на перле.
Обсуждают сегодня