Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
 Аватар для Dinkin
783 / 556 / 136
Регистрация: 31.05.2013
Сообщений: 3,149
Записей в блоге: 3

Объединение ячеек в Excel

06.04.2015, 16:29. Показов 4456. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня!
Не могу объединить ячеек при экспорте StringGrid в Excel, возникает ошибка "Не верный тип переменой" (Без объединения все хорошо).

C++ (Qt)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Variant app,wbs,wss,ws,cell;
if (MAIN->SaveDialog1->Execute())
{
    app = CreateOleObject("Excel.Application");
    app.OlePropertyGet("Workbooks").OleProcedure("Add");
    wbs = app.OlePropertyGet("Workbooks").OlePropertyGet("Item", 1);
    wbs.OleProcedure("SaveAs", StringToOleStr(MAIN->SaveDialog1->FileName));
    wss = wbs.OlePropertyGet("Worksheets");
    ws = wss.OlePropertyGet("Item", 1);
    for (int r = 0; r < sg->RowCount; r++)
        for (int c = 0; c < sg->ColCount; c++)
        {
            cell = ws.OlePropertyGet("Cells", r + 1, c + 1);
            cell.OlePropertySet("Value", StringToOleStr(sg->Cells[c][r]));
        }
 
    ws.OlePropertyGet("Range", "A1:F3").OlePropertyGet("Select").OleProcedure("Merge");
 
    wbs.OleProcedure("Save");
    app.OleProcedure("Quit");
 
    }
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.04.2015, 16:29
Ответы с готовыми решениями:

Объединение ячеек в StringGrid
Можно ли объединить две соседние ячейки в StringGrid? Если да, то куда копать? Как это сделать?

[C++ Builder XE] TcxSpreadSheetBook. Объединение ячеек.
Здравсвуйте! Кто работал с компонентом TcxSpreadSheetBook. Подскажите как в нем можно объеденить ячейки? Спасибо!

Работа с Ole Word (Объединение ячеек таблицы)
Нужно в C++Builder при работе с ole объединить две ячейки таблицы в Word. Может кто знает?

7
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33378 / 21502 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 11
06.04.2015, 20:38
Лучший ответ Сообщение было отмечено Dinkin как решение

Решение

C++
1
2
    ws.OlePropertyGet("Range", WideString("A1:F3")).OleProcedure("Select");
    app.OlePropertyGet("Selection").OleProcedure("Merge");
, но Excel выбросит тебе окно с предупреждением, что ты потеряешь данные (кроме значения в верхнем левом углу) при подобном объединении ячеек.
1
 Аватар для Dinkin
783 / 556 / 136
Регистрация: 31.05.2013
Сообщений: 3,149
Записей в блоге: 3
06.04.2015, 22:16  [ТС]
А как правильно объединять ячейки где уже есть информация?
0
Модератор
 Аватар для D1973
9916 / 6453 / 2455
Регистрация: 21.01.2014
Сообщений: 27,389
Записей в блоге: 3
07.04.2015, 18:21
Dinkin, но ведь даже просто в Excel, без Билдера, при объединении диапазона А1:F3 грохнутся все данные, кроме тех, что находятся в ячейке A1...
Костыль:
1. Создать строковую переменную S
2. Последовательным добавлением записать в нее данные из всех ячеек нужного диапазона
3. Объединить диапазон ячеек (A1:F3)
4. Записать в ячейку A1 значение переменной S
1
Почетный модератор
Эксперт С++
 Аватар для SatanaXIII
5851 / 2862 / 392
Регистрация: 01.11.2011
Сообщений: 6,906
08.04.2015, 09:06
D1973, даже чуть переиначить лучше подход, с учетом слов UI - чтобы не выскакивало предупреждение.
Сперва скопировать содержимое ячеек в переменную, затем очистить их, и пустые уже объединить.
2
 Аватар для Dinkin
783 / 556 / 136
Регистрация: 31.05.2013
Сообщений: 3,149
Записей в блоге: 3
08.04.2015, 10:19  [ТС]
При таком объединение всегда выходит сообщение о потери данных (даже если ячейки пусты) =). Решил отказаться от это идеи и просто делаю заливку ячеек, визуально в итоге очень схоже.
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33378 / 21502 / 8236
Регистрация: 22.10.2011
Сообщений: 36,899
Записей в блоге: 11
08.04.2015, 13:15
Цитата Сообщение от Dinkin Посмотреть сообщение
всегда выходит сообщение о потери данных (даже если ячейки пусты)
Неправда. Только что проверил, при пустых ячейках нет сообщения. Раз получаешь такое сообщение - значит, у тебя в объединяемых ячейках есть пробельные символы.
1
Модератор
 Аватар для D1973
9916 / 6453 / 2455
Регистрация: 21.01.2014
Сообщений: 27,389
Записей в блоге: 3
08.04.2015, 16:25
Цитата Сообщение от SatanaXIII Посмотреть сообщение
затем очистить их
Ну конечно же... Упустил этот шаг в алоритме... Спасибо за подсказку.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.04.2015, 16:25
Помогаю со студенческими работами здесь

Перебор ячеек Excel
Имеется таблица Excel, в которой необходимо перебрать ячейки пока не появится пустое значение в столбце. Вот так вот проверяет и...

Копирование листа excel с сохранением формата ячеек
Добрый день! Копирую лист с одного excel файла в другой вот таким способом: vTemp=wSheet1.OlePropertyGet(&quot;Range&quot;,...

Как ускорить выгрузку в Excel из DBGrid с созданием рамок для ячеек?
Всем доброго времени суток! Делаю выгрузку в Exel из своих DBGrid'ов там же создаю рамку для каждой ячейки void __fastcall...

Выгрузка данных в Excel (добавление нужного количества строк с объединением ячеек)
Добрый день! Пару дне уже бьюсь не могу найти решения. Подскажите ребята. Нужное количество данных нужно выгрузить в шаблон Excel. Выгрузка...

Форматирование ячеек в Excel
задача в том, чтобы експортировать из DBGrid в Excel данние но сохранив то форматирование которое они имеют в DBGrid в цикле делаю, вот...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru