Поиск в ArrayList (на примере Android-приложения)

Добавлено: 10/07/2018 14:48 |  Обновлено: 11/07/2018 08:01 |  Добавил: nick |  Просмотры: 268 Комментарии: 1
Вводная часть
В этом материале описан пример, демонстрирующий поиск в ArrayList. Поиск будет работать по такому же принципу, что и оператор SQL LIKE. В качестве рабочей платформы используем систему Android. Поиск осуществляется с помощью регулярных выражений.
Как это работает можно увидеть в моем приложении «Секретные карточки». Страница приложения в Google Play. ×
Для примера используем следующий ArrayList:
ArrayList<String> al = new ArrayList<>();
al.add("Книги бывают разные\nчернила во второй строке");
al.add("Карандаши лежат на полке");
al.add("Чернила черные\nкниги во второй строке");
al.add("Чернила черные и чернила красные");
al.add("Чернила синие");
al.add("Журнал взяла учительница");
Создадим новый проект в Android Studio. Для примера можно использовать Empty Activity.

В окно приложения нужно перетащить кнопку, поле ввода (EditText) и текстовое поле (TextView). Поле ввода нужно для ввода искомой фразы, а текстовое поле для вывода того, что нашлось. Кнопка запускает поиск.

В результате содержимое файла activity_main.xml у вас должно получиться примерно следующим:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <Button
        android:id="@+id/button3"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="8dp"
        android:layout_marginLeft="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:onClick="onClick"
        android:text="НАЙТИ"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/editText" />

    <EditText
        android:id="@+id/editText"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginEnd="8dp"
        android:layout_marginLeft="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:ems="10"
        android:inputType="textPersonName"
        android:text=""
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <TextView
        android:id="@+id/textView2"
        android:layout_width="0dp"
        android:layout_height="0dp"
        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginLeft="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:gravity="center_horizontal"
        android:text="Впишите в строку искомую фразу и нажмите кнопку &quot;НАЙТИ&quot;"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/button3" />

</android.support.constraint.ConstraintLayout>
Осталось в файл MainActivity.java добавить необходимый для работы примера код.
public class MainActivity extends AppCompatActivity {

    private EditText editText;
    private TextView textView;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        editText = findViewById(R.id.editText);
        textView = findViewById(R.id.textView2);

    }

    public void onClick(View view) {

        ArrayList<String> al = new ArrayList<>();
        al.add("Книги бывают разные\nчернила во второй строке");
        al.add("Карандаши лежат на полке");
        al.add("Чернила черные\nкниги во второй строке");
        al.add("Чернила черные и чернила красные");
        al.add("Чернила синие");
        al.add("Журнал взяла учительница");

        // Получаем введенное значение из EditText
        Editable text = editText.getText();

        // Сюда будем добавлять найденные элементы из первого списка al
        ArrayList<String> al2 = new ArrayList<>();

        // Ищем все совпадения в списке al и добавляем их в список al2
        for (String temp : al) {
            if (temp.matches("(?is)" + ".*" + Pattern.quote(text.toString()) + ".*")) {
                al2.add(temp);
            }
        }

        // Формируем строку со всеми найденными совпадениями
        // и выводим ее в TextView
        String all = "";
        for (String temp : al2) {
            all += temp + "\n";
        }
        textView.setText(all);

    }
}
Готовое приложение: На сайте есть также материал, в котором описывается как добавить виджет поиска в App Bar, прочитав оба материала вы научитесь использовать виджет поиска вместо EditText.

Комментарии

  • 11/07/2018 02:22 Dmitry Ghost пишет:

    Просто и понятно, спасибо! Будет ли статья о RecyclerView Swipe to Delete and Undo?

    nick пишет:
    Скорее всего будет статья по RecyclerView Drag&Drop и Swipe to Delete.

Оставьте свой комментарий