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

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

16.04.2012, 16:50. Показов 6017. Ответов 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-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru