Реализация экспорта данных (CSV, Excel) из мобильного приложения

TRUETECH занимается разработкой, поддержкой и обслуживанием мобильных приложений iOS, Android, PWA. Имеем большой опыт и экспертизу для публикации мобильных приложений в популярные маркеты Google Play, App Store, Amazon, AppGallery и другие.
Разработка и поддержка любых видов мобильных приложений:
Информационные и развлекательные мобильные приложения
Новостные приложения, игры, справочники, онлайн-каталоги, погодные, фитнес и здоровье, туристические, образовательные, социальные сети и мессенджеры, квиз, блоги и подкасты, форумы, агрегаторы
Мобильные приложения электронной коммерции
Интернет-магазины, B2B-приложения, маркетплейсы, онлайн-обменники, кэшбэк-сервисы, биржи, дропшиппинг-платформы, программы лояльности, доставка еды и товаров, платежные системы
Мобильные приложения для управления бизнес-процессами
CRM-системы, ERP-системы, управление проектами, инструменты для команды продаж, учет финансов, управление производством, логистика и доставка, управление персоналом, системы мониторинга данных
Мобильные приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, платформы предоставления электронных услуг, платформы кешбека, видеохостинги, тематические порталы, платформы онлайн-бронирования и записи, платформы онлайн-торговли

Это лишь некоторые из типы мобильных приложений, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента.

Предлагаемые услуги
Показано 1 из 1 услугВсе 1735 услуг
Реализация экспорта данных (CSV, Excel) из мобильного приложения
Простая
~2-3 рабочих дня
Часто задаваемые вопросы
Наши компетенции:
Этапы разработки
Последние работы
  • image_mobile-applications_feedme_467_0.webp
    Разработка мобильного приложения для компании FEEDME
    756
  • image_mobile-applications_xoomer_471_0.webp
    Разработка мобильного приложения для компании XOOMER
    624
  • image_mobile-applications_rhl_428_0.webp
    Разработка мобильного приложения для компании RHL
    1052
  • image_mobile-applications_zippy_411_0.webp
    Разработка мобильного приложения для компании ZIPPY
    947
  • image_mobile-applications_affhome_429_0.webp
    Разработка мобильного приложения для компании Affhome
    862
  • image_mobile-applications_flavors_409_0.webp
    Разработка мобильного приложения для компании FLAVORS
    445

Реализация экспорта данных (CSV, Excel) из мобильного приложения

Пользователь нажимает «Экспортировать» — и ждёт. Если у него 5000 строк в локальной SQLite или Room-базе, а экспорт происходит на main thread, приложение замирает секунды на три, а на старых устройствах ANR (Application Not Responding) не заставит себя ждать. Это первая и самая частая ошибка при реализации экспорта.

Что на практике ломается чаще всего

Блокировка UI при генерации файла. Сериализация 10 000 строк в CSV — это не «мгновенная операция». На Android нужен CoroutineScope(Dispatchers.IO), на iOS — DispatchQueue.global(qos: .userInitiated). Генерацию файла всегда выносим в фоновый поток, результат возвращаем через callback или Flow.

Кодировка и разделитель. CSV — это ловушка. Excel в Windows по умолчанию ожидает кодировку Windows-1252 и разделитель ;, а не ,. Если отдать UTF-8 без BOM — кириллица превратится в кракозябры прямо в офисе клиента. Правильный CSV для Excel: UTF-8 с BOM (\uFEFF в начале файла) и разделитель ;. Либо сразу экспортировать .xlsx через библиотеку.

Экспорт в Excel (.xlsx). На Android используем Apache POI или более лёгкий FastExcel. На iOS — xlsxwriter через Swift Package или собственный XML-генератор (.xlsx — это ZIP с XML-файлами внутри). Для React Native есть react-native-xlsx поверх js-библиотеки xlsx.

Как строим экспорт

Схема простая: читаем данные из локальной БД → трансформируем в модель строк → пишем в файл → делимся через системный ShareSheet / Intent.ACTION_SEND.

На Android с Room это выглядит так:

viewModelScope.launch(Dispatchers.IO) {
    val rows = database.transactionDao().getAll()
    val file = CsvExporter.export(rows, context.cacheDir)
    withContext(Dispatchers.Main) {
        shareFile(file, "text/csv")
    }
}

На iOS аналогично через Task.detached:

Task.detached(priority: .userInitiated) {
    let rows = await store.fetchAll()
    let url = try CsvExporter.write(rows, to: .cachesDirectory)
    await MainActor.run { presentShareSheet(url) }
}

Для .xlsx на iOS генерируем XML-структуру вручную или через CoreXLSX / xlsxwriter. Для простых таблиц — XML-подход быстрее и без зависимостей.

Прогресс при большом объёме

Если строк больше 50 000 — показываем ProgressView с реальным процентом. На Android через StateFlow<Int> в ViewModel, на iOS через @Published var progress: Double. Пишем файл батчами по 1000 строк, обновляем счётчик после каждого батча.

Формат файла и Share

После генерации файл кладём в cacheDir (Android) или FileManager.default.temporaryDirectory (iOS). Делимся через:

  • Android: FileProvider + Intent.ACTION_SEND с правильным MIME-типом (text/csv или application/vnd.openxmlformats-officedocument.spreadsheetml.sheet)
  • iOS: UIActivityViewController с [fileURL]

Не сохраняем в Downloads без явного запроса пользователя — это нарушает гайдлайны обеих платформ.

Что входит в работу

  • Выбор формата (CSV / XLSX) и согласование структуры колонок
  • Фоновая генерация файла без блокировки UI
  • Корректная кодировка и локализация разделителей
  • Прогресс-индикатор для больших выгрузок
  • Шаринг через системный ShareSheet / Intent
  • Тесты на реальных объёмах данных

Сроки

Простой CSV-экспорт из готовой базы данных: 0,5–1 день. С выбором формата (CSV/XLSX), фильтрами по диапазону дат и прогрессом: 1,5–2 дня. Стоимость рассчитывается после анализа структуры данных.