s
sander-00719 мая 2020 г. 15:08

Использование файлов в памяти (memory file mapping)

Добрый день, у Шлее в книге прочитал файлами в памяти можно пользоваться как обычными файлами. Можно-ли реализовать такую вещь: генерируем файл Excel и открываем его без создания файла на диске? Кто-нибудь делал?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

5
Evgenii Legotckoi
  • 20 мая 2020 г. 15:57

Добрый день.
Думается мне, что тут скорее другая проблема будет, сама по себе работа с файлом.
Уже здесь достаточно много вопросов по работе с Excel файлами возникало, но чаще это были проблемы с подключением к файлу, поскольку для работы с ними используется адаптер.
С самим Excel файлом я бы не пробовал этого делать ))

    s
    • 21 мая 2020 г. 15:09

    Добрый вечер, поподробнее опишу :)

    Сейчас я читаю шаблон отчета Exel из базы в QbyteArray, сохраняю на диск и потом заполняю. Что нибудь с массивом можно делать, без сохранения на диск?

      Evgenii Legotckoi
      • 22 мая 2020 г. 2:34

      Ну с самим QByteArray можно что угодно сделать перед формированием файла.
      Придётся только повозиться с его структурой. Но если там чисто Excel структура документа, то есть у вас уже готовый Excel файл находится в том QByteArray, то будет весьма тяжело что-то сделать с этим массивом. Реверс-инжениринг никогда не был лёгкой задачей.

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

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

      QFile file("foo");
      file.open(QFile::ReadWrite);
      uchar *memory = file.map(0, file.size());
      if (memory) {
          // have some fun with the data
          file.unmap();
      }
      

      Могу предположить, что пока не вызыван метод unmap() , то данные полностью не будут уложены на физический диск.
      Попробуйте создавать такой файл с маппингом, работать с ним, а потом просто очищать и удалять.
      В данном случае, предполагаю, что у вас будет создаваться файл на физическом диске, но вы сможете поработать с ним в памяти, возможно также, как работали с ним до этого.

      Но говорю сразу, это мои предположения. Сам я такого не реализовывал. Так что, отпишитесь о результатах, если будет успешно.

        Docent
        • 25 мая 2020 г. 12:41
        • (ред.)

        Есть еще такой вариант.
        "Вот вам файл Exel.xml, там внутри логи работы прибора, автоматизируте построение графиков в отдельных окошках с прокрутками и другими плюшками"
        Окау
        Подключаемся к файлу через драйвер БД, смотрим структуру и выкачиваем данные запросами...
        Как оказалось файл был псевдо-Exel - обычный текстовый файл с разделением данных табуляцией, но сохранён как ".xml".
        Задача сильно упростилась до обычного парсинга, но и через драйвер БД тоже работала, только дольше и сложнее

          s
          • 25 мая 2020 г. 14:24

          Добрый вечер, проблемы работы с файлом Exel нет вообще. Весь смысл в том чтобы не создавать на диске физический файл (требования безопасности), дабы потом не чистить. А так вопрос только в этом :)

            Комментарии

            Только авторизованные пользователи могут публиковать комментарии.
            Пожалуйста, авторизуйтесь или зарегистрируйтесь
            AD

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:50баллов,
            • Очки рейтинга-4
            m
            • molni99
            • 26 октября 2024 г. 8:37

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:80баллов,
            • Очки рейтинга4
            m
            • molni99
            • 26 октября 2024 г. 8:29

            C++ - Тест 004. Указатели, Массивы и Циклы

            • Результат:20баллов,
            • Очки рейтинга-10
            Последние комментарии
            i
            innorwall12 ноября 2024 г. 6:12
            Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
            i
            innorwall12 ноября 2024 г. 2:23
            QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
            i
            innorwall11 ноября 2024 г. 23:50
            Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
            i
            innorwall11 ноября 2024 г. 22:19
            Алгоритм сортировки кучей The role of raloxifene in preventing breast cancer priligy precio
            i
            innorwall11 ноября 2024 г. 21:55
            PyQt5 - Урок 006. Работа с QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
            Сейчас обсуждают на форуме
            i
            innorwall12 ноября 2024 г. 4:56
            добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
            i
            innorwall11 ноября 2024 г. 18:55
            Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
            9
            9Anonim25 октября 2024 г. 16:10
            Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
            ИМ
            Игорь Максимов3 октября 2024 г. 11:05
            Реализация навигации по разделам Спасибо Евгений!

            Следите за нами в социальных сетях