Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/32: Рейтинг темы: голосов - 32, средняя оценка - 4.97
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247

Программный экспорт в Excel из reportViewer

16.04.2012, 16:50. Показов 6025. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В reportViewer'e есть кнопка по нажатии которой можно экспортировать в Excel, а как мне повесить на свою кнопку код, по нажатии которой будет происходить экспорт в Excel из reportViewer'a?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.04.2012, 16:50
Ответы с готовыми решениями:

Экспорт в Excel: Прекращена работа программы "Microsoft Excel"
Файл сохраняется успешно, но поле строки excelApp.Quit(); Появляется окно ошибки Excel: Прекращена работа программы "Microsoft...

Экспорт в excel
Всем привет, есть кнопка импорта и сохранения в exсel но при повторном нажатии говорит о том что файл уже существует перезаписать? вот...

Экспорт dataGridView в MS Excel
Всем привет. Есть задача написать экспорт из DataGridView в файл excel. Как понимаю для этого нужно подключить...

8
 Аватар для dimasamchenko
336 / 269 / 21
Регистрация: 30.03.2009
Сообщений: 500
17.04.2012, 10:48
Монфрид, Вот таким образом

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
this.MainTBLTableAdapter.FillBy(this.Customer.MainTBL, SF);//Заполняем отчет Здесь Ваши данные !!!
      this.reportViewer1.RefreshReport(); //обновляем его
 
      Warning[] warnings;
      string[] streamids;
      string mimeType;
      string encoding;
      string extension;
 //PDF Экспорт
      byte[] bytes = reportViewer1.LocalReport.Render(
         "Pdf", null, out mimeType, out encoding,
          out extension,
         out streamids, out warnings);
 
      FileStream fs = new FileStream(@"output.pdf",
         FileMode.Create);
      fs.Write(bytes, 0, bytes.Length);
      fs.Close();
 
 
 // Excel  Экспорт
      byte[] bytes1 = reportViewer1.LocalReport.Render(
                "Excel", null, out mimeType, out encoding,
                 out extension,
                out streamids, out warnings);
 
      FileStream fs1 = new FileStream(@"output.xls",
         FileMode.Create);
      fs1.Write(bytes1, 0, bytes1.Length);
      fs1.Close();
весь выше указаный код поместите в обработчик кнопки или в отдельную функцию вызываемую из обработчика кнопки
2
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
17.04.2012, 18:29  [ТС]
если что, то я решил вот так:
C#
1
2
if (reportViewer1.ExportDialog(reportViewer1.LocalReport.ListRenderingExtensions()[0]) == System.Windows.Forms.DialogResult.OK)
                    MessageBox.Show("Документ был сохранён");
3
7 / 7 / 1
Регистрация: 04.12.2009
Сообщений: 42
26.09.2013, 10:49
Цитата Сообщение от Монфрид Посмотреть сообщение
если что, то я решил вот так:
C#
1
2
if (reportViewer1.ExportDialog(reportViewer1.LocalReport.ListRenderingExtensions()[0]) == System.Windows.Forms.DialogResult.OK)
                    MessageBox.Show("Документ был сохранён");

Монфрид, можешь кусок кода побольше выложить, ато не особо понимаю куда эту строку притулить
2
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
26.09.2013, 11:24  [ТС]
Sanek911, тут уж полней куска кода нет. Куда хочешь (на кнопку например) туда и вешай этот код. Главное чтобы репортвьювер был на форме
0
7 / 7 / 1
Регистрация: 04.12.2009
Сообщений: 42
26.09.2013, 11:32
Операция является недопустимой из-за текущего состояния объекта.

вот такая ошибка у меня

ReportViewer есть на форме

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
       public FormReportView(Object DataTable, String ReportDataSetname, String NameReport, String NameReportRDLC) {
            InitializeComponent();
 
            Microsoft.Reporting.WinForms.ReportDataSource
                reportDataSource1 = SetParameters(ReportDataSetname, DataTable, NameReportRDLC);
            rpview.RefreshReport();
            if (rpview.ExportDialog(rpview.LocalReport.ListRenderingExtensions()[0]) == System.Windows.Forms.DialogResult.OK)
                MessageBox.Show("Документ был сохранён");
 
            this.Close();
        }
 
        private Microsoft.Reporting.WinForms.ReportDataSource SetParameters(
            String ReportDataSourceName, Object DataTable, String ReportName) 
        {
            Microsoft.Reporting.WinForms.ReportDataSource 
                reportDataSource1 = new Microsoft.Reporting.WinForms.ReportDataSource();
 
            reportDataSource1.Name = ReportDataSourceName;
            reportDataSource1.Value = DataTable;
            this.rpview.LocalReport.DataSources.Add(reportDataSource1);
            this.rpview.LocalReport.ReportEmbeddedResource = ReportName;
            return reportDataSource1;
        }
0
 Аватар для Монфрид
1245 / 1055 / 293
Регистрация: 07.03.2012
Сообщений: 3,247
26.09.2013, 11:51  [ТС]
так, ну вы в конструктор напихали всё что можно.
вынесите код экспорта на отдельную кнопку
0
7 / 7 / 1
Регистрация: 04.12.2009
Сообщений: 42
26.09.2013, 12:17
Я не знаю как вы сделали, но используя ваш вариант я подразумевал, что форма содержащая ReportViewer не будет отображаться.
С вашим вариантом необходимо отображать форму.
Я сделал как предлагали ранее. Спасибо за уделенное время.
0
3 / 3 / 6
Регистрация: 31.05.2014
Сообщений: 177
01.08.2016, 18:00
dimasamchenko, подскажите пожалуйста, мне нужно авто генерация отчета в excel и отправкой его на почту, но отчет написанный в report builder, Вы можете что то посоветовать? Может написать небольшое приложение на c# используя вашу часть кода и переписать отчет в reportviewer ? Но смогу ли я потом поставить эту программу на планировщик?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.08.2016, 18:00
Помогаю со студенческими работами здесь

экспорт из datagridview в excel
Здравствуйте!помогите вернуть отредактированный фаил datagridview в excel!Открываю яего таким способом а как его пересохранить? ...

Экспорт в DataGridView в Excel
как экспортировать таблицу datagridview в Excell на С#

Экспорт DataGridView в Excel
Доброго времени суток. Мне необходима помощь. Не выходит выполнить экспорт в Excel возникает ошибка. Помогите пожалуйста. Программа...

Экспорт из DataGridView в Excel!
Здравствуйте!!! Возникла такая проблема. На Form1 имеется striptmenu, в котором есть функция "Новый". Появляется новая форма...

Экспорт из DataGridView в Excel
Здравствуйте!!! Возникла проблема. На форме1 имеется striptmenu в котором есть вкладка "Новая". При нажатии появляется форма2 и...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
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