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

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

16.04.2012, 16:50. Показов 5916. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Blazor и контроллер сервопривода IoT Meadow Maple
Wired 11.07.2025
Я решил разобраться, как можно соединить современные веб-технологии с миром "железа". Интересная комбинация получилась из Blazor в качестве веб-интерфейса и микроконтроллера Meadow с его веб-сервером. . .
Генерация OpenQASM из кода Q#
EggHead 10.07.2025
Летом 2024-го я начал эксперименты с библиотекой Q# Bridge, и знаете что? Она оказалась просто находкой для тех, кто работает на стыке разных квантовых экосистем. Основная фишка этой библиотеки -. . .
Изучаем новый шаблон ИИ-чата .NET AI Chat Web App
stackOverflow 10.07.2025
В . NET появилось интересное обновление - новый шаблон ИИ-чата под названием . NET AI Chat Web App. Когда я впервые наткнулся на анонс этого шаблона, то сразу понял, что Microsoft наконец-то. . .
Результаты исследования от команды ARP (июль 2025 г.)
Programma_Boinc 10.07.2025
Результаты исследования от команды ARP (июль 2025 г. ) Африканский проект по дождям (ARP) World Community Grid снова запущен! Мы рады поделиться обновленной информацией о нашем прогрессе с осени. . .
Angular vs Svelte - что лучше?
Reangularity 09.07.2025
Сегодня рынок разделился на несколько четких категорий: тяжеловесы корпоративного уровня (Angular), гибкие универсалы (React), прогрессивные решения (Vue) и новая волна компилируемых фреймворков. . .
Code First и Database First в Entity Framework
UnmanagedCoder 09.07.2025
Entity Framework дает нам свободу выбора, предлагая как Code First, так и Database First подходы. Но эта свобода порождает вечный вопрос — какой подход выбрать? Entity Framework — это. . .
Как использовать Bluetooth-модуль HC-05 с Arduino
Wired 08.07.2025
Bluetooth - это технология, созданная чтобы заменить кабельные соединения. Обычно ее используют для связи небольших устройств: мобильных телефонов, ноутбуков, наушников и т. д. Работает она на частоте. . .
Руководство по структурам данных Python
AI_Generated 08.07.2025
Я отчетливо помню свои первые серьезные проекты на Python - я писал код, он работал, заказчики были относительно довольны. Но однажды мой наставник, взглянув на мою реализацию поиска по огромному. . .
Тестирование энергоэффективности и скорости вычислений видеокарт в BOINC проектах
Programma_Boinc 08.07.2025
Тестирование энергоэффективности и скорости вычислений видеокарт в BOINC проектах Опубликовано: 07. 07. 2025 Рубрика: Uncategorized Автор: AlexA Статья размещается на сайте с разрешения. . .
Раскрываем внутренние механики Android с помощью контекста и манифеста
mobDevWorks 07.07.2025
Каждый Android-разработчик сталкивается с Context и манифестом буквально в первый день работы. Но много ли мы задумываемся о том, что скрывается за этими обыденными элементами? Я, честно говоря,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru