<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        asp.net 動態生成rdlc報表(原創)

        來源:懂視網 責編:小采 時間:2020-11-27 22:42:29
        文檔

        asp.net 動態生成rdlc報表(原創)

        asp.net 動態生成rdlc報表(原創): 代碼如下:string cCount = ; string dCount = ; string jCount = ; protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string id = Request.QueryString[Order
        推薦度:
        導讀asp.net 動態生成rdlc報表(原創): 代碼如下:string cCount = ; string dCount = ; string jCount = ; protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string id = Request.QueryString[Order

        代碼如下:

        string cCount = "";
        string dCount = "";
        string jCount = "";
        protected void Page_Load(object sender, EventArgs e)
        {
        if (!IsPostBack)
        {
        string id = Request.QueryString["OrderID"] == null ? "1" : Request.QueryString["OrderID"].ToString();
        SqlConnection con = new SqlConnection("server=CHENZQ;uid=sa;pwd=luca623;database=luca");
        SqlDataAdapter sda = new SqlDataAdapter("select * from view_Order where C_orderID='" + id + "'", con);
        DataSet ds = new DataSet();
        sda.Fill(ds);
        cCount = ds.Tables[0].Rows[0]["C_CTime"].ToString();
        dCount = ds.Tables[0].Rows[0]["C_TTime"].ToString();
        jCount = ds.Tables[0].Rows[0]["C_DTime"].ToString();
        //這段代碼是最重要
        ReportViewer1.Reset();
        this.ReportViewer1.LocalReport.LoadReportDefinition(GenerateRdlc());
        ReportViewer1.LocalReport.DataSources.Clear();
        //Orders_DataTable1 數據源名字必須和此報表原綁定的數據源名相同
        this.ReportViewer1.LocalReport.DataSources.Add(new ReportDataSource("Orders_DataTable1", ds.Tables[0]));
        this.ReportViewer1.LocalReport.Refresh();
        }
        }
        //這個方法就是自定義報表的樣式
        public MemoryStream GenerateRdlc()
        {
        XmlDocument sourceDoc = new XmlDocument();
        string path = AppDomain.CurrentDomain.BaseDirectory + "Orders.rdlc";
        //c_CTime = ds.Tables[0].Rows[0]["C_CTime"].ToString();
        sourceDoc.Load(path);
        //下面就是xml操作了 沒必要看我的 根據自己的需求而做
        XmlNode xHeader = sourceDoc.ChildNodes.Item(1).ChildNodes.Item(13).ChildNodes.Item(1).ChildNodes.Item(0).ChildNodes.Item(4);
        XmlNode xCells = xHeader.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(0);
        //建設期
        XmlNode xmlCell = xCells.ChildNodes.Item(1);
        XmlElement xeCol = sourceDoc.CreateElement("ColSpan");
        xeCol.InnerText = cCount;
        xeCol.InnerXml = cCount;
        xmlCell.InnerXml += xeCol.OuterXml;
        XmlNode xmlCellValue = xmlCell.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValue.InnerXml = "建設期";
        xmlCellValue.InnerText = "建設期";
        XmlNode xnRemove;
        for (int i = 0; i <int.Parse(cCount) - 1; i++)
        {
        xnRemove = xCells.ChildNodes.Item(2);
        xCells.RemoveChild(xnRemove);
        }
        //投產期
        XmlNode xmlCellT = xCells.ChildNodes.Item(2);
        XmlElement xeColT = sourceDoc.CreateElement("ColSpan");
        xeColT.InnerText = dCount;
        xeColT.InnerXml = dCount;
        xmlCellT.InnerXml += xeColT.OuterXml;
        XmlNode xmlCellValueT = xmlCellT.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValueT.InnerXml = "投產期";
        xmlCellValueT.InnerText = "投產期";
        for (int j = 0; j < int.Parse(dCount) - 1; j++)
        {
        xnRemove = xCells.ChildNodes.Item(3);
        xCells.RemoveChild(xnRemove);
        }
        //生產期
        XmlNode xmlCellC = xCells.ChildNodes.Item(3);
        XmlElement xeColC = sourceDoc.CreateElement("ColSpan");
        xeColC.InnerText = jCount.ToString();
        xeColC.InnerXml = jCount.ToString();
        xmlCellC.InnerXml += xeColC.OuterXml;
        XmlNode xmlCellValueC = xmlCellC.ChildNodes.Item(0).ChildNodes.Item(0).ChildNodes.Item(4);
        xmlCellValueC.InnerXml = "生產期";
        xmlCellValueC.InnerText = "生產期";
        for (int j = 0; j < int.Parse(jCount) - 1; j++)
        {
        xnRemove = xCells.ChildNodes.Item(4);
        xCells.RemoveChild(xnRemove);
        }
        MemoryStream ms = new MemoryStream();
        XmlSerializer serializer = new XmlSerializer(typeof(XmlDocument));
        serializer.Serialize(ms, sourceDoc);
        ms.Position = 0;
        return ms;
        }

        技巧 可以先在報表里自己設計好需要的格式 用
        XmlDocument sourceDoc = new XmlDocument();
        string path = AppDomain.CurrentDomain.BaseDirectory + "Orders.rdlc";
        然后用sourceDoc .save()保存生成xml
        可以看到此xml你需要改的格式是哪個地方

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        asp.net 動態生成rdlc報表(原創)

        asp.net 動態生成rdlc報表(原創): 代碼如下:string cCount = ; string dCount = ; string jCount = ; protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) { string id = Request.QueryString[Order
        推薦度:
        標簽: 生成 動態 net
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日韩免费在线视频| 中文字幕成人免费高清在线视频| 亚洲专区先锋影音| 亚洲欧洲日韩在线电影| 亚洲乱码在线观看| 国产精品免费一区二区三区| 久久久免费的精品| 国产精品视_精品国产免费| 久久久久亚洲爆乳少妇无 | 亚洲人精品午夜射精日韩| 亚洲精品自在线拍| 成人无码视频97免费| 国产亚洲精品资源在线26u| 亚洲av色香蕉一区二区三区| 亚洲视频在线观看免费| 亚洲va久久久噜噜噜久久天堂| 久久亚洲欧美国产精品| 亚洲成av人片天堂网老年人| 亚洲午夜电影在线观看高清| 一级毛片大全免费播放下载| 男人的好免费观看在线视频| 国产亚洲精品无码专区 | 免费99精品国产自在现线| 精品亚洲成α人无码成α在线观看 | 国产亚洲av人片在线观看| 亚洲国产精品无码久久| 最近免费中文字幕mv电影| 亚洲综合色视频在线观看| 亚洲爆乳精品无码一区二区| 免费人成年激情视频在线观看| 亚洲制服丝袜中文字幕| 91在线老王精品免费播放| 亚洲成_人网站图片| 久久亚洲欧洲国产综合| 麻豆高清免费国产一区| 亚洲高清无在码在线电影不卡| 国产免费MV大全视频网站| 久久青青草原亚洲av无码| 91人成网站色www免费下载| 亚洲AV成人片无码网站| 久久久久亚洲AV成人无码|