标题:[求助]怎样打印datagrid中的数据
只看楼主
ck_kk123
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2006-5-17
 问题点数:0 回复次数:7 
[求助]怎样打印datagrid中的数据

怎样在C#中打印datagrid中的数据,用报表吗?

搜索更多相关主题的帖子: datagrid 数据 打印 
2006-05-20 11:46
hanyou
Rank: 1
等 级:新手上路
威 望:1
帖 子:105
专家分:0
注 册:2005-4-2
得分:0 
好像有一个这样的类库!
2006-05-21 12:35
hanyou
Rank: 1
等 级:新手上路
威 望:1
帖 子:105
专家分:0
注 册:2005-4-2
得分:0 
你可以到网上找找看!
2006-05-21 12:35
an163126
Rank: 1
等 级:新手上路
帖 子:95
专家分:0
注 册:2005-3-19
得分:0 
这个没有做过,也不知道怎么做的!

 发哥:透在骨里的酷
2006-05-21 12:46
凌枫影
Rank: 2
等 级:新手上路
威 望:3
帖 子:163
专家分:0
注 册:2006-5-10
得分:0 
打印?
是输出还是用打印机啊

2006-05-21 15:42
googleknow
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-5-19
得分:0 
咱还没有做过这样的功能呢!
2006-05-21 18:40
鸿鹄之志
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-4-14
得分:0 

2005中使用reportView控件就可以打印啦,
先做一个表样,再把数据源绑定上

2006-05-22 16:12
鸿鹄之志
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2006-4-14
得分:0 

通过控件打印

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Text;
using System.Windows.Forms;
using Microsoft.Reporting.WinForms;

namespace HhSoft.His.Zygl
{
public partial class ReportFrm : Form
{

private HHsoft_HisDataSet HHsoft_HisDataSet1;//类型DataSet实例
private string formTitle ; //打印名称
private string reportTableName ; //样表名称
private string dataSetName ; //数据源名称
private string tableName ; //数据源的表名
private string reportSourceName ; //数据源名称_表名
private DataTable reportDataTable; //要打印的表
private ReportParameter[] reportParameter ;//样表需要的参数集合


public ReportFrm()
{
InitializeComponent();
}

private void ReportFrm_Load(object sender, EventArgs e)
{
this.reportViewer1.RefreshReport();
}
/// <summary>
/// 打印报表
/// </summary>
/// <param name="frmTit">打印标题</param>
/// <param name="repTabName">样表名称</param>
/// <param name="dsName">数据源名称</param>
/// <param name="tabName">数据表名称</param>
/// <param name="tab">需要打印的数据表</param>
/// <param name="repParameter">打印样表需要的参数</param>
public void ReportTable(string frmTit,string repTabName,string dsName,string tabName,DataTable tab,ReportParameter[] repParameter)
{
formTitle = frmTit;
reportTableName = repTabName;
dataSetName = dsName;
tableName = tabName;
reportDataTable = tab;
reportParameter = repParameter;
reportSourceName = dsName + "_" + tabName;

Report();

}

private void FillDataSet()
{
for (int i = 0; i < reportDataTable.Rows.Count; i++ )
{
HHsoft_HisDataSet1.Tables[tableName].ImportRow(reportDataTable.Rows[i]);
}
}
private void Report()
{
reportViewer1.Reset();
this.components = new System.ComponentModel.Container();
this.Text = formTitle;
HHsoft_HisDataSet1 = new HHsoft_HisDataSet();
HHsoft_HisDataSet1.DataSetName = dataSetName;

HHsoft_HisDataSet1.SchemaSerializationMode = SchemaSerializationMode.IncludeSchema;

System.Windows.Forms.BindingSource patientinhosbedBindingSource = new BindingSource(this.components);
patientinhosbedBindingSource.DataMember = tableName;
patientinhosbedBindingSource.DataSource = HHsoft_HisDataSet1;
HHsoft_HisDataSetTableAdapters.patientinhosbedTableAdapter patientinhosbedTableAdapter = new HhSoft.His.Zygl.HHsoft_HisDataSetTableAdapters.patientinhosbedTableAdapter();
patientinhosbedTableAdapter.ClearBeforeFill = true;
FillDataSet();//填充数据

Microsoft.Reporting.WinForms.ReportDataSource ReportSource = new Microsoft.Reporting.WinForms.ReportDataSource();

ReportSource.Name = reportSourceName;
ReportSource.Value = patientinhosbedBindingSource;

reportViewer1.LocalReport.DataSources.Add(ReportSource);
reportViewer1.LocalReport.ReportEmbeddedResource = reportTableName;
reportViewer1.LocalReport.SetParameters(reportParameter);
reportViewer1.LocalReport.DisplayName = formTitle;


}

自己还要做个表样

2006-05-22 16:22



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-65746-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.764497 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved