Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/15: Рейтинг темы: голосов - 15, средняя оценка - 5.00
 Аватар для Midian
606 / 388 / 198
Регистрация: 31.03.2013
Сообщений: 2,690

Копирование ячеек Excel

13.07.2015, 12:14. Показов 2932. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня, столкнулся с проблемой, не могу понять почему выпадает исключение, собственно есть код, который открывает 2 Excel файла и из одного листа файла 1, копирует данные в другой файл (Excel 2013):
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
Microsoft.Office.Interop.Excel.Application ObjWorkExcelInput = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel.Workbook ObjWorkBookInput = ObjWorkExcelInput.Workbooks.Open(textBoxPromotionalSales.Text, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
            Microsoft.Office.Interop.Excel.Worksheet ObjWorkSheetInput = (Microsoft.Office.Interop.Excel.Worksheet)ObjWorkBookInput.Sheets["Promotional-Sales"];
            Microsoft.Office.Interop.Excel.Application ObjWorkExcelOutput = new Microsoft.Office.Interop.Excel.Application();
            Microsoft.Office.Interop.Excel.Workbook ObjWorkBookOutput = ObjWorkExcelOutput.Workbooks.Open(@"C:\Users\pnavitsk\Desktop\Работа\Выходной файл (тестовый)", Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing, Type.Missing);
            Microsoft.Office.Interop.Excel.Worksheet ObjWorkSheetOutput = (Microsoft.Office.Interop.Excel.Worksheet)ObjWorkBookOutput.Sheets["Promotional sales"];
            var lastCell = ObjWorkSheetInput.Cells.SpecialCells(Microsoft.Office.Interop.Excel.XlCellType.xlCellTypeLastCell);
            try
            {
                ObjWorkSheetOutput.Cells.Clear();
                for (int i = 1; i < (int)lastCell.Row; i++)
                    for (int j = 1; i < (int)lastCell.Column; j++)
                        ObjWorkSheetOutput.Cells[i, j].Value2 = ObjWorkSheetInput.Cells[i, j].Value2;
                //ObjWorkBookOutput.Sheets["Promotional sales"].Copy(Before: ObjWorkBookInput.Sheets["Promotional-Sales"]);
            }
            catch (Exception ex) { MessageBox.Show(ex.Message); }
            finally
            {
                ObjWorkBookInput.Close(false, Type.Missing, Type.Missing);
                ObjWorkBookOutput.Close(true, Type.Missing, Type.Missing);
                ObjWorkExcelInput.Quit(); ObjWorkExcelOutput.Quit(); GC.Collect();
            }
Собственно вопрос, что я делаю не так?
Само исключение такое:
Изображения
 
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.07.2015, 12:14
Ответы с готовыми решениями:

Скопировать диапазон ячеек одной книги Excel в другую книгу Excel
Из темы все ясно... Не могу разобраться никак. Можно ли открыть одну книгу, скопировать диапазон куда-нибудь, потом открыть другую книгу......

Копирование выделенных ячеек DataGrid
Есть такое &lt;DataGrid Name=&quot;SpecTable&quot; AutoGenerateColumns=&quot;False&quot; ...

Копирование диапазона ячеек из Excel в Word
Приветствую. Уважаемые, столкнулся с проблемой копированя диапазона ячеек из Excel в Word. Имеется лист Экселя который...

1
 Аватар для Midian
606 / 388 / 198
Регистрация: 31.03.2013
Сообщений: 2,690
13.07.2015, 18:00  [ТС]
Погуглил и нашел на форуме примеры кода, попробовал у себя, но он вставляет не как текст, а как картинку:
C#
1
2
3
4
5
for (int i = 1; i < (int)lastCell.Row; i++)
                {
                    ObjWorkSheetInput.get_Range("A" + i.ToString(), "E" + i.ToString()).Copy(Type.Missing);
                    ObjWorkSheetOutput.get_Range("A" + i.ToString(), "E" + i.ToString()).PasteSpecial();
                }
Как забрать текст?

Добавлено через 46 минут
Бред, написал так и все заработало, хотя до этого вываливалось исключение.... Не понятно ничего
C#
1
2
3
4
5
for (int i = 1; i < (int)lastCell.Row; i++)
                    for (int j = 1; j < (int)lastCell.Column; j++)
                    {
ObjWorkSheetOutput.Cells[i, j] = ObjWorkSheetInput.Cells[i, j];
                    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.07.2015, 18:00
Помогаю со студенческими работами здесь

Копирование выделенных несмежных ячеек таблицы excel
Доброго вечера. Ломаю голову над следующей задачей. Есть таблица с данными. В ручную выделяем произвольные строки с нажатым CTRL...

Копирование ячеек из книги excel в таблицу access
Здравствуйте. Подскажите, пожалуйста, как с помощью vba скопировать ячейки из книги excel в таблицу access. и можно ли подключить...

Копирование ячеек из книги excel в таблицу access
Здравствуйте. Подскажите, пожалуйста, как с помощью vba скопировать ячейки из книги excel в таблицу access. и можно ли подключить...

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

Excel копирование определенных ячеек и строк на другой лист
Здравствуйте. Имеется лист с которого нужно при нажатии кнопки скопировать определенные данные на другой лист построчно в определенные...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
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 Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru