|
| |
精品推荐 |
 |
|
| |
|
|
|
|
ASP.NET中应用XML技术实现Web报表打印
|
日期:2008年4月23日 作者: 查看:[大字体
中字体 小字体]
|
{
DataGrid dg = GetDataGrid(i);
if(dtReport.Rows[i]["PageSize"].ToString() != String.Empty)
{
//分页打印
dg.AllowPaging = true;
dg.PagerStyle.Mode = PagerMode.NumericPages;
dg.PagerStyle.PageButtonCount = 10;
dg.PageSize = Convert.ToInt32(dtReport.Rows[i]["PageSize"].ToString());
}
DataSet ds = new DataSet();
//从Report.xml读取数据源信息
if(dtReport.Rows[i]["SQLdataConnection"].ToString() != String.Empty)
{
//数据提供者为SQL Server
SqlConnection Conn = new SqlConnection(dtReport.Rows[i]["SQLdataConnection"].ToString());
SqlDataAdapter myDataAdapt = new SqlDataAdapter(dtReport.Rows[i]["Sql"].ToString(),Conn);
myDataAdapt.Fill(ds,dtReport.Rows[i]["TableName"].ToString());
}
else if(dtReport.Rows[i]["OleDbConnection"].ToString() != String.Empty)
{
//数据提供者为OLE DB
OleDbConnection Conn = new OleDbConnection(dtReport.Rows[i]["OleDbConnection"].ToString());
OleDbDataAdapter myDataAdapt = new OleDbDataAdapter(dtReport.Rows[i]["Sql"].ToString(),Conn);
myDataAdapt.Fill(ds,dtReport.Rows[i]["TableName"].ToString());
}
//用通用页面显示报表
dg.DataSource = ds;
dg.DataBind();
}
}
}
catch
{
labelPageTitle.Text = "The requested report could not be found";
}
}
3.3 创建定制打印页面
需要在XML文档ApplyXSLT标签内添加对应的xslt文件名,并制作相应的样式表放在项目的xslt文件夹下即可。如下代码添加到通用打印程序中。
if(dtPage.Rows[0]["ApplyXSLT"].ToString() != string.Empty )
{
//用xsl显示报表
XmlDataDocument xmlDoc = new XmlDataDocument(ds);
XslTransform xslTran = new XslTransform();
xslTran.Load(Server.MapPath("xslt\\"+dtPage.Rows[0]["ApplyXSLT"].ToString()));
XmlTextWriter writer = new XmlTextWriter(Server.MapPath("XSLTReports.aspx"), System.Text.Encoding.UTF8);
xslTran.Transform(xmlDoc, null, writer);
writer.Close();
Response.Redirect("XSLTReports.aspx");
}
应用xslt样式表可以制作出专业的报表样式,为方便制作,在此推荐使用XMLSpy带的Stylesheet。
(出处:清风网络学院)
上一篇:英文感谢信模板
下一篇:利用XMLHTTP 从其他页面获取数据
|
| 相关文章: |
|
|
|
| 相关软件: |
|
|
|
|