233 / 95 / 15
Регистрация: 31.12.2009
Сообщений: 224

Как в Excel найти середину области печати

31.12.2009, 10:24. Показов 4852. Ответов 5
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте, уважаемые участники форума.
Вкрадце о задаче: Имеется отчёт в Excel, который делаю по шаблону с помощью своего компонента-обёртки над ExcelApplication. Лист гарантировано заполняется менее чем наполовину. Необходимо продублировать сформированную часть отчёта с середины листа. Как это сделать? Заранее благодарен.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
31.12.2009, 10:24
Ответы с готовыми решениями:

Задание области печати листа Excel программным путем
Доброго времени суток. Пытаюсь сделать банальную вещь - вывести отчет на принтер из программы. Проблема в том, что моя табличка не...

Как узнать координаты области печати?
Вопрос стоит следующим образом. Я устанавливаю размер страницы и ориентацию для принтера: printer->setPaperSize(QPrinter::A4); ...

Печать: как сделать перенос строки в области печати
Вечер добрый! В проекте печатаю документ (с помощью PrintDialog), но строка уходит в неизвестность :( Как сделать так, чтобы при...

5
233 / 95 / 15
Регистрация: 31.12.2009
Сообщений: 224
11.01.2010, 10:08  [ТС]
Вопрос был не из лёгких )).

Тему закрываю, решил проблему сам
0
233 / 95 / 15
Регистрация: 31.12.2009
Сообщений: 224
11.01.2010, 16:38  [ТС]
Не трудно. Но решение не блещет гибкостью.
Ещё раз хочется разъяснить задачу, т.к. в прошлый раз я, возможно, недостаточно полно её описал.
Генерирую отчёт в Excel. Использую свой компонент на основе TExcelApplication и шаблоны. Отчёты получаются небольшие, т.е. умещаются на половине листа. По заданию необходимо делать копию полученной "верхней" части отчёта внизу таким образом, чтобы лист можно было разрезать пополам и части получились бы одинаковые половинки. Надеюсь понятно написал ). Найти какие либо св-ва и методы, позволяющие получить строку, указывающую на середину печатаемой области листа мне не удалось. А без этой строки, ясно дело, я не могу скопировать содержимое "верха" по ценру листа.
Решил проблему дубово. Посчитал количество пикселей до середины листа в самом шаблоне (пусть будет H), и после формирования "верха" выполняю поиск номера строки считая сумму высот строк H[i] пока не дойду до H. i и будет искомая строка. Проблема в том, что такой способ годится только для жёстко заданных шаблонов, т.е. если вы что-то в нём сменили(например, поля), придётся менять исходник, что есть ОЧЕНЬ плохо, т.к. я именно от этого и хотел отказаться.

Вообще цель моих изысканий заключается в том, чтобы минимально менять код, а максимально всё делать в шаблоне. Если кто знает хорошую литературу, не поскупитесь, киньте ссылку. Закрытые компоненты не интересуют. Заранее спасибо.
1
 Аватар для snake32
3471 / 1655 / 236
Регистрация: 26.02.2009
Сообщений: 8,118
Записей в блоге: 6
31.01.2010, 21:44
Не знаю на сколько эта литература окажется полезной, но там как раз MS Excel и Word(правда для делфи):
Программирование документов и приложений MS Office в Delphi
0
233 / 95 / 15
Регистрация: 31.12.2009
Сообщений: 224
01.02.2010, 14:34  [ТС]
Могу я уточнить, собственно, источник?
Цитата Сообщение от snake32 Посмотреть сообщение
Программирование документов и приложений MS Office в Delphi
- это название книги? Или статьи?
0
 Аватар для snake32
3471 / 1655 / 236
Регистрация: 26.02.2009
Сообщений: 8,118
Записей в блоге: 6
01.02.2010, 16:43
Это книга
http://samouchka.net/ebooks/ya... jj-ms.html
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.02.2010, 16:43
Помогаю со студенческими работами здесь

Excel при печати разбивает область печати по ячейкам
При масштабировании страницы (чтобы документ влез на одну страницу) Ексель автоматом определяет новые области печати на каждую ячейку...

Как на основной области страницы создать область печати (textarea) с привязкой к активному элементу дерева?
товарищи, уперся в недостаток опыта и знаний... 1. нажимаю на элемент дерева он выделяется красным. как зафиксировать это состояние,...

Как найти середину даты между двумя датами
Прошу помочь решить такую задачку в PHP. ест 2 дата 1. 2015-11-20 2. 2016-02-20 Нужно вычислить какой дата между ними. ...

Как найти середину треугольника по координатам его вершин
как найти середину треугольника по его координатам?

Как найти середину массива или центральный элемент к блоке?
A это 3Д массив, A =, где a_N это 2Д массив. Мне нужно собрать 2Д массив в блоки по 2,3,4 и тд штук и найти средний элемент. ...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Опции темы

Новые блоги и статьи
Компиляция C++ с Clang API
NullReferenced 24.03.2025
Компиляторы обычно воспринимаются как черные ящики, которые превращают исходный код в исполняемые файлы. Мы запускаем компилятор командой в терминале, и вуаля — получаем бинарник. Но что если нужно. . .
Многопоточное программировани­е в C#: Класс Thread
UnmanagedCoder 24.03.2025
Когда запускается приложение на компьютере, операционная система создаёт для него процесс - виртуальное адресное пространство. В C# этот процесс изначально получает один поток выполнения — главный. . .
SwiftUI Data Flow: Передача данных между представлениями
mobDevWorks 23.03.2025
При первом знакомстве со SwiftUI кажется, что фреймворк предлагает избыточное количество механизмов для передачи данных: @State, @Binding, @StateObject, @ObservedObject, @EnvironmentObject и другие. . . .
Моки в Java: Сравниваем Mockito, EasyMock, JMockit
Javaican 23.03.2025
Как протестировать класс, который зависит от других сложных компонентов, таких как базы данных, веб-сервисы или другие классы, с которыми и так непросто работать в тестовом окружении? Для этого и. . .
Архитектурные паттерны микросервисов: ТОП-10 шаблонов
ArchitectMsa 22.03.2025
Популярность микросервисной архитектуры объясняется множеством важных преимуществ. К примеру, она позволяет командам разработчиков работать независимо друг от друга, используя различные технологии и. . .
Оптимизация рендеринга в Unity: Сортировка миллиона спрайтов
GameUnited 22.03.2025
Помните, когда наличие сотни спрайтов в игре приводило к существенному падению производительности? Время таких ограничений уходит в прошлое. Сегодня геймдев сталкивается с задачами совершенно иного. . .
Образование и практика
Igor3D 21.03.2025
Добрый день А вот каково качество/ эффективность ВУЗовского образования? Аналитическая геометрия изучается в первом семестре и считается довольно легким курсом, что вполне справедливо. Ну хорошо,. . .
Lazarus. Таблица с объединением ячеек.
Massaraksh7 21.03.2025
Понадобилась представление на экране таблицы с объединёнными ячейками. И не одной, а штук триста, и все разные. На Delphi я использовал для этих целей TStringGrid, и то, кривовато получалось. А в. . .
Async/await в Swift: Асинхронное программировани­е в iOS
mobDevWorks 20.03.2025
Асинхронное программирование долго было одной из самых сложных задач для разработчиков iOS. В течение многих лет мы сражались с замыканиями, диспетчеризацией очередей и обратными вызовами, чтобы. . .
Колмогоровская сложность: Приёмы упрощения кода
ArchitectMsa 20.03.2025
Наверное, каждый программист хотя бы раз сталкивался с кодом, который напоминает запутанный лабиринт — чем дальше в него погружаешься, тем сложнее найти выход. И когда мы говорим о сложности кода, мы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru