1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
1 | |
Работа с Excel. Суть: Если номер строки в Excel четный тогда объеденяем эту ячейку с последующей.08.05.2012, 10:55. Показов 7296. Ответов 26
Метки нет (Все метки)
Здравствуйте. Помогите, пожалуйста .Я вот в Delphi осуществляю работу с документов в Excel, как я могу записать, чтобы выполнялся алгоритм: если номер строки в Excel четный, тогда объеденяем эту ячейку с последующей.
0
|
08.05.2012, 10:55 | |
Ответы с готовыми решениями:
26
Как получить результат, если формула в Excel вписана в ячейку!??? Cpp builder-Ole-Excel. WideString пишет в ячейку Excel минус перед нулем Excel: Очистить ячейку если та что справа окрашена в зеленый цвет Сформировать новый массив по правилу: если номер элемента четный, то Ai=Ci; если номер элемента нечетный, то Ai=2 |
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
||||||
08.05.2012, 14:55 | 2 | |||||
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 17:42 [ТС] | 3 |
А что такое Col и Row, куда это прописать?
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
||||||
08.05.2012, 17:51 | 4 | |||||
Row и Col - это номера строки и столбца. RowCnt - это общее количество строк, которые надо бработать. Все эти переменные принадлежат типу Integer. Объявить их нужно в разделе VAR того метода или процедуры, где эти переменные предполагается использовать.
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 18:14 [ТС] | 5 |
у меня просто есть процедура, там происходит удаление определенных строк, и я туда же вставила ваш код, и вот при запуске выдает ошибку Invalid operator
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
|
08.05.2012, 18:26 | 6 |
Код надо адаптировать к своему проекту. Переменная exSheet должна быть инициализирована - эта переменная должна содержать ссылку на интерфейс листа Excel. Чтобы что-то конкретное посоветовать в этом случае, мне нужно увидеть код, в который предполагается добавить действия по объединению ячеек.
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
||||||
08.05.2012, 18:39 [ТС] | 7 | |||||
Да, пожалуйста..)
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
||||||
08.05.2012, 18:52 | 8 | |||||
можно сделать так:
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 19:09 [ТС] | 9 |
Спасибо, А почему в Excel при объединении ячеек которая нижняя исчезает а не объеденяется.) я хочу как бы чтобы они сливались в одну строку)))
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
|||||||||||
08.05.2012, 19:11 | 10 | ||||||||||
Если обрабатывается большое количество строк, то работа Excel может сильно замедлиться из-за перерисовок окна при выполнении операций. Чтобы ускорить работу можно на время обработки отключить перерисовку окна Excel:
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 19:17 [ТС] | 11 |
Можете это на моем коде показать? а то кажется не туда вставляю. Ошибку выдает..
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
|
08.05.2012, 19:18 | 12 |
При объединении ячеек в результирующей объединённой ячейке остаётся только содержимое из верхней левой ячейки объединяемого диапазона. Содержимое других ячеек пропадает.
Чтобы в объединённую ячейку перенести содержимое из всех ячеек в объединяемом диапазоне - это надо вручную делать. - Прочитать из всех ячеек значения, построить из этих значений одну строку и записать её в объединённую ячейку.
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 19:21 [ТС] | 13 |
Ого..Все так сложно?)))
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
||||||
08.05.2012, 19:32 | 14 | |||||
Я сейчас напишу, как надо сделать...
--- Вот:
0
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 21:57 [ТС] | 15 |
Ой, спасибо))) Слушайте, а чтоьы ячейки объединялись во 2-ом столбце мне нужно Col := 2 и все?
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
|
08.05.2012, 22:40 | 16 |
Почти. В коде переменная Col обозначает номер столбца. И эта переменная применяется и при удалении и при объединении. Если для удаления нужно просматривать 1-й столбец, а при объединении - 2-й, то соответственно, перед удалением надо присвоить: Col := 1, а перед циклом объединения: Col := 2.
1
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
08.05.2012, 23:44 [ТС] | 17 |
Ой, спасибо, за помощь)) Что бы я без вас делала))
Добавлено через 33 минуты Слууушайте))) А никак нельзя сделать сортировку этих строк по алфавиту? еще + к тем действиям.
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
||||||
09.05.2012, 00:07 | 18 | |||||
Сортировка диапазона выполняется с помощью метода Sort(). Т. е., нужно определить диапазон (Range), в котором надо выполнить сортировку. Затем, для этого диапазона вызвать метод Sort().
1
|
1 / 1 / 0
Регистрация: 03.11.2011
Сообщений: 54
|
|
09.05.2012, 07:22 [ТС] | 19 |
А как для сортировки второго столбца сделать? И будет ли он сортировать с объединенными ячейками?) И этот код я должна написать перед finally да?
Добавлено через 3 минуты Выдает ошибку, говоря, что для сортировки ячейки должны быть одинакового размера.
0
|
13107 / 5888 / 1707
Регистрация: 19.09.2009
Сообщений: 8,808
|
|
09.05.2012, 17:26 | 20 |
Сортировать можно только диапазон, который содержит одинаковые по своему строению ячейки. Поэтому здесь надо определиться - или сортировать до объединения ячеек или сортировку можно сделать после объединений, но сортируемый диапазон должен включать только эти объединённые ячейки. Или может потребуется какой-то другой подход. Это зависит от того, какая логика расположения данных на листе.
Если нужно отсортировать только данные второго столбца после объединений ячеек, для этого случая я сейчас напишу как должно быть...
0
|
09.05.2012, 17:26 | |
09.05.2012, 17:26 | |
Помогаю со студенческими работами здесь
20
Embarcadero, excel, ошибка записи в ячейку строки (не верный тип данных) Выделение цветом строки в Excel 2007, при нажатии на соседнюю ячейку Выгрузка строки файла в ячейку Excel средствами VBA. Требуется подсказка Сформировать массив из исходного по правилу: если номер четный, то Р1=М1+i,если нечетный, то Р1=М1 В табеле задать значение если праздничный день отмечен красным тогда суммируем в отдельную ячейку Как узнать букву колонки Excel, если у меня есть ее номер Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Опции темы | |
|
Новые блоги и статьи | |||||
Использование связки C# и PHP в корпоративной разработке и микросервисной архитектуре
InfoMaster 16.01.2025
Введение в интеграцию C# и PHP
В современной корпоративной разработке все чаще возникает потребность в создании гибких и масштабируемых решений, способных эффективно решать широкий спектр. . .
|
Как использовать Kerio дома для управления сетью и пользователями
InfoMaster 16.01.2025
Использование технологий для улучшения повседневной жизни стало неотъемлемой частью современного быта. Одной из таких технологий является Kerio — мощный инструмент для управления сетью и. . .
|
Есть ли будущее у DVD и Blu-ray?
InfoMaster 16.01.2025
В эпоху стремительного развития цифровых технологий и повсеместного распространения потоковых сервисов вопрос о будущем физических носителей информации становится все более актуальным. Особенно остро. . .
|
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
|
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
|
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
|
Параллельное программирование: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование
Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
|
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
|
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке
В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
|
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
|
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins
В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
|
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang
Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
|