/airport-search

Консольная программа, которая ищет данные по CSV файлу. ( A console program that searches for data in a CSV file. )

Primary LanguageJavaMIT LicenseMIT

airport-search

  1. Корректная обработка ошибок (Correct error handling):
  • Программа бросате RuntimeException и выводит информационное сообщение в консоль при возникновении IOException во время чтения файла, а также при указании некорректного значения столбца, по которому осуществляется поиск.
    ( The program throws a RuntimeException and displays an informational message to the console when an IOException occurs while reading a file, and also when an incorrect value is specified for the column being searched. )
  • Когда отлавливается NumberFormatException при попытке считать число (Double) из строки (String), которую ввел пользователь, программа просто изменяет параметр isNumeric, необходимый для корректной сортировки данных.
    ( When a NumberFormatException is caught when trying to read a number (Double) from a string (String) entered by the user, the program simply changes the isNumeric parameter, which is necessary to sort the data correctly. )
  1. Так как CSV файл использует UTF-8(Since the CSV file uses UTF-8):
  • Все источники и .jar используют кодировку UTF-8, поэтому для корректного отображения символов в консоли необходимо использовать следующие флаги для JVM:
    ( All sources and .jar use UTF-8 encoding, so the following flags for the JVM must be used to display characters correctly in the console: )

-Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8

Описание(Description):

Консольная программа, которая ищет данные по CSV файлу, ячейки которых начинаются на переданную в консоли строку. Столбец по-которому осуществляется поиск передается единственным параметром при запуске .jar. Есть на выбор 2 версии, одна , использующая PrefixTree для хранилища идексов использует больше памяти, чем другая, которая использует реализаию Dictionary. Если данных относительно немного, то выигрывает Dictionary, но чем больше будет данных, тем эффективнее будет PrefixTree в сравнении с Dictionary. Это происходит из-за того, что словарь делит столбец на разделы, ключами для которых являются первые символы данных в нем. К примеру jar, использующий флаг JVM, который ограничивает память до 7МБ:

-Xmx7m

Не будет работать с реализацией PrefixTree, в отличие от другого, с Dictionary.

( A console program that searches for data in a CSV file whose cells begin with a string passed to the console. The column to search by is passed as the only parameter when the .jar is run. There are 2 versions to choose from, one that uses the PrefixTree for index storage uses more memory than the other that uses the Dictionary implementation. If there is relatively little data, Dictionary wins, but the more data there is, the more efficient PrefixTree will be compared to Dictionary. This is because the dictionary divides the column into sections, the keys for which are the first characters of the data in it. For example, a jar that uses a JVM flag that limits memory to 7MB:

-Xmx7m

Will not work with the PrefixTree implementation, but with the Dictionary does. )