Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате |
Форум программистов > Разработка Windows Forms > Распечатать датасет ввиде таблицы |
Автор: Gesha 6.7.2006, 11:33 |
Как при помощи CrystalReports распечатать датасет ввиде таблицы (vs 2005). |
Автор: mr.DUDA 6.7.2006, 12:40 | ||||
По шагам: 1) создаём Windows Application 2) добавляем в проект новый типизированный датасет "Add New Item... / DataSet" 3) в дизайнере добавляем в датасет таблицу с нескольколькими колонками Теперь создадим отчёт (на выходе получится файл .rpt, который можно будет отредактировать в дизайнере) 4) добавляем в проект новый репорт "Add New Item... / Crystal Report", открывается окно мастера 4.1) ничего не меняя на первой странице, жмём OK 4.2) на второй странице раскрываем дерево до "Project Data / ADO.NET DataSets / WindowsApplication1.DataSet1 / DataTable1", жмём кнопку ">" - после этого датасет и таблица появится в списке "Selected Tables", жмём кнопку "Далее" 4.3) на третьей странице добавляем в список "Fields to display" те колонки, которые будут выводиться в отчёте 4.4) на четвёртой странице можно настроить группировку (необязательно), на пятой - фильтрацию (тоже необязательно) 4.5) последняя страница ("Report Style"), выбираем "Table" - это задаёт стиль отображения отчёта в виде простой таблицы, жмём "Готово" Всё, шаблон отчёта создали, теперь поехали с печатью. Печатать можно двумя способами: первый - используя стандартный компонент "Crystal Report Viewer" с тулбокса, второй способ - чисто программно (без preview). И в том, и в другом случае, потребуется создать экземпляр отчёта. Можно сделать это, просто перетянув на форму компонент "Report Document", в открывшемся окне выбираем наш отчёт в списке доступных отчётов. Также нужно создать экземпляр датасета, наполнить его данными, и привязать к отчёту. Каким способом создавать датасет - не играет роли, можно хоть программно, хоть перетянув "DataSet" с тулбокса на форму. Как наполнять данными - надеюсь, объяснять не надо. Теперь о привязке к отчёту: это делается вызовом метода SetDataSource отчёта. Например:
Последнее, как распечатать отчёт. Если без preview - просто вызываем PrintToPrinter:
Если хотим посмотреть preview, просто добавляем на форму компонент "CrystalReportViewer" и выставляем в его свойствах "Report Source" равным нашему отчёту "WindowsApplication1.CrystalReport1". Печать происходит по нажатию соотв. кнопки на тулбаре. |
Автор: ivashkanet 6.7.2006, 12:43 |
Где-то так я и думал. Все автоматизировано. 2 mr.DUDA: А не лень тебе было это все писать. |
Автор: mr.DUDA 6.7.2006, 15:35 |
(offtop) сам заодно разобрался, иногда такое полезно делать ![]() |
Автор: CityAC 26.10.2007, 22:54 | ||||
mr.DUDA, Поднимаю старую тему, для меня это сейчас актуально Сделал все как написал в этой ветке mr.DUDA. Все компилится , но отчет не заполняется данными.
Какие требования тут существуют, например количество колонок в таблице отчета должно совпадать с кол-вом колонок в источнике данных и др.? У меня например в таблице отчета 8 колонок, а в источнике FindDt их аж 21(они мне нужны!) Как мне в отчет включить не все колонки, которые есть в источнике данных, а выборочно. Продебагил этот код только что и что я вижу
этот строка показывает, что после провязки моего датасета к отчету, отчет содержит ноль строк ![]() Спасайте в понедельник надо принести на работу прогу со сделанными отчетами ДОБАВЛЕНО ЧЕРЕЗ 15 МИНУТ Разобрался, оказывается немного не понял то, что описал mr.DUDA теперь осталось красиво оформит сам отчет, ну это уже как два пальца об асфальт |
Автор: Doss 10.12.2008, 11:05 |
mr.DUDA, вы гений и это не лесть, без Ваших подсказок и помощи что бы я делал, встати это всех касается, кто принимает участие на форуме, помогаете человеку стать человеком ![]() Спасибо тебе Vingrad спасобо тебе программирование.... ![]() |
Автор: albert21 30.9.2011, 12:57 | ||||
Добрый день. Делаю всё также как в описании mr.DUDA. Но я DataSet заполняю не из базы данных, а сам:
Дальше привязываю DataSet к отчёту, а отчёт к View-еру
на этапе выполнения ошибка: не может найти файл crdb_adoplus.dll. Ошибка возникает на строчке r.SetDataSource(ds); Если эту строчку закомментировать, то появляется окно с view-ером и форма с предложением ввести логин, пароль, имя сервера и базы данных. Как отключить запрос на вход в БД? Ведь у меня работы с БД нету, датасет заполняется "вручную" |
Автор: albert21 1.10.2011, 11:52 |
На данный момент решил отказаться от использования Crystal Report. Альтернатива - репортинговая система Win Forms. Мне она показалось проще. В msdn есть руководство по использованию без подключения к БД. Вот ссылка: http://msdn.microsoft.com/ru-ru/library/ms251784.aspx |