Форум программистов, компьютерный форум, киберфорум
C/C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/8: Рейтинг темы: голосов - 8, средняя оценка - 4.50
1 / 1 / 1
Регистрация: 13.12.2014
Сообщений: 19
1

Переставить листы в Excel

18.01.2017, 21:26. Показов 1547. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Всем здрасте.
Хотел поменять в экселе листы местами (3-й с 4-м), но возникла проблема:
C++
1
2
3
4
5
         item = knigi.OlePropertyGet("Item", 1).OlePropertyGet("WorkSheets");
         list2 = item.OlePropertyGet("Item", 2);
         list3 = item.OlePropertyGet("Item", 3);
         list4 = item.OlePropertyGet("Item", 4);
         list4.OleProcedure("Move", list3, list2);
Builder 6 на последней строчке выдаёт ошибку E2247.
Кто- нибудь может сказать, чего она мне мозг конопатит? Как это можно устранить? Или есть ли другой способ поменять листы местами?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.01.2017, 21:26
Ответы с готовыми решениями:

Копировать одноименные листы из файлов Excel в один файл Excel
nshardarbekov@mail.ru Добрый день, уважаемые! Помогите пожалуйста создать макрос, для того чтобы собрать (скопировать) листы с...

Копировать листы из файлов Excel в один файл Excel
Добрый день, господа! Помогите создать макрос, для того чтобы собрать(скопировать) листы из разных файлов Excel в один файл Excel. ...

Перенос данных excel -excel на разные листы
Доброго времени суток. Возникла небольшая проблема: Переношу данные из книги в книгу, но в каждой книге по 3 листа, а данные...

3
1 / 1 / 1
Регистрация: 13.12.2014
Сообщений: 19
19.01.2017, 23:09  [ТС] 2
Специально, чтобы избавиться от этой ошибки, установил Builder XE, перелопатил программу, и ... выдаёт ровно ту-же самую ошибку.
0
Модератор
 Аватар для vxg
3401 / 2172 / 353
Регистрация: 13.01.2012
Сообщений: 8,428
20.01.2017, 06:32 3
Romi_k, в ВБА этот код пробовали?
0
1 / 1 / 1
Регистрация: 13.12.2014
Сообщений: 19
20.01.2017, 12:24  [ТС] 4
Лучший ответ Сообщение было отмечено vxg как решение

Решение

Нет, не пробовал
Но дело сдвинулось. Я поменял тип переменной list2 - list4 с "OleVariant" на просто "Variant". Строитель перестал мозги полоскать, но теперь во время работы вылазит ошибка "OleSysError" на последней строчке.

Добавлено через 46 минут
Короче, всё заработало.
Поменял последнюю строчку на
C++
1
list3.OleProcedure("Move", EmptyParam, list4);
и готово дело.
Правда, работает почему-то только с "EmptyParam".
Если, например, нужно поменять местами 2-ю и 3-ю строчку, то вот так не работает:
C++
1
list2.OleProcedure("Move", list4, list3);
а вот так - пожалуйста:
C++
1
list2.OleProcedure("Move", EmptyParam, list3);
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
20.01.2017, 12:24
Помогаю со студенческими работами здесь

Листы Excel в C#
Подскажите пожалуйста, может кто-то знает, как менять название листов в Excel из C#. Тоесть нужно вместо стандартных подписей (внизу на...

StringGrid и Excel листы
Как добавить лист в excel в конец книги? for i:=4 to 12 do Workbook.Sheets.Add; After:=Worksheets(Worksheets.Count); Вот так...

Защищённые листы в Excel
Доброго времени суток товарищи! Подключаюсь через ADO к Excel такой строкой подключения: string ConnectionString =...

Объединить листы excel в один
Доброе время суток! Еще раз нуждаюсь в вашей помощи! Нужен макрос для объединение разных таблиц (книг) excel в один как в примере. ...

Не могу создать новые листы Excel
В общем у меня есть процедура, которая в добавок ко всему создает новый лист excel (если это требуется) и переносит туда данные. Ругается...


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Что нового в C# 14
UnmanagedCoder 10.03.2025
Предстоящая версия C# 14 обещает принести изменения, которые сделают разработку еще более приятной и эффективной. Что стоит отметить, так это влияние сообщества разработчиков на формирование новых. . .
Формулы поворота
Igor3D 10.03.2025
Добрый день Тема Эти формулы приводятся во множестве тьюториалов, часто под видом "матрица вращения на плоскости". x' = x * cos(a) - y * sin(a) y' = y * cos(a) + x * sin(a) Как бы Вы их. . .
Что нового в .NET 10
UnmanagedCoder 10.03.2025
. NET 10 выходит как релиз с длительной поддержкой (LTS), включающей три года обновлений. В этом обновлении Microsoft сфокусировались на нескольких направлениях: производительность, оптимизация. . .
Отложенное высвобождение, RCU и Hazard Pointer в C++26
NullReferenced 09.03.2025
Многопоточное программирование стало важной частью современной разработки. Когда несколько потоков одновременно работают с общими данными, возникает целый ряд проблем, связанных с синхронизацией и. . .
Неблокирующийся стек на C++26
NullReferenced 09.03.2025
Традиционные способы синхронизации в многопоточном программировании — мьютексы, семафоры, условные переменные — часто превращаются в узкое место в плане производительности. При этом неблокирующиеся. . .
Обработка строк в C++26: Новые возможности string и string_view
NullReferenced 09.03.2025
Новый стандарт C++26 предлагает много улучшений для работы с привычными string и относительно новыми string_view. string_view - это невладеющая ссылка на последовательность символов, появившаяся в. . .
Мой первый аддон для Blender 3D, с помощью нейронки (не зная даже азов пайтона, но это не значит что так и с остальным).
Hrethgir 09.03.2025
Потратил весь день. Пол-дня мне хватило, чтобы понять что с версией с 14B мне не одолеть написание функционального кода, на языке с которым я вообще никак не знаком - пайтон. Версия 22B от другого. . .
Einstein@Home сегодня исполняется двадцать лет!
Programma_Boinc 09.03.2025
Einstein@Home сегодня исполняется двадцать лет! Отправлено 19 февраля 2025 года в 17:20:21 UTC Я хочу поздравить всех наших волонтеров, разработчиков и ученых из Einstein@Home. Мы официально. . .
Заполнители и расширенный набор символов в C++26
NullReferenced 09.03.2025
C++26 представляет два важных обновления: заполнители и расширенный набор символов. Заполнители (placeholders) решают давнюю проблему лаконичности кода в шаблонных выражениях и лямбда-функциях. Они. . .
Контракты в C++26
NullReferenced 09.03.2025
Контракты – это механизм, позволяющий указывать предусловия, постусловия и инварианты для функций в коде. Эта функциональность должна была стать частью C++20, но была исключена на встрече комитета. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru