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

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

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

Студворк — интернет-сервис помощи студентам
Здравствуйте, уважаемые участники форума.
Вкрадце о задаче: Имеется отчёт в 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
3511 / 1694 / 236
Регистрация: 26.02.2009
Сообщений: 8,483
Записей в блоге: 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
3511 / 1694 / 236
Регистрация: 26.02.2009
Сообщений: 8,483
Записей в блоге: 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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru