溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法

發(fā)布時間:2021-07-22 22:44:19 來源:億速云 閱讀:125 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

當我們在使用RDLC開發(fā)報表的時候,如果數(shù)據(jù)源內(nèi)容如下。

復(fù)制代碼 代碼如下:


private List<UserData> CreateDataSet()
{
    List<UserData> userDataSet = new List<UserData>();
    userDataSet.Add(new UserData() { Name = "Clark", Age = 18 });
    userDataSet.Add(new UserData() { Name = "Yaya", Age = 15 });
    return userDataSet;
}

我們可以很快速的使用RDLC里的數(shù)據(jù)表控件,來將數(shù)據(jù)呈現(xiàn)在報表上。

.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法

但是當客戶要求下圖的報表,要將數(shù)據(jù)源內(nèi)容顯示在一行。RDLC處理這種需求就沒有那么簡單,這是因為RDLC沒有循環(huán)處理的函式可以使用。造成開發(fā)人員要組合數(shù)據(jù),必須使用隱藏列表、在外部組合字符串…等等迂回的方式建立報表內(nèi)容。但這樣的方式開發(fā),既沒有效率而且也有很多的限制。

.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法

這個問題困擾了我好幾天,昨晚睡到一半忽然有靈感??梢允褂肦DLC里的Sum函式,來做數(shù)據(jù)循環(huán)的處理。

Sum函式會取得數(shù)據(jù)集中的每一筆資料,并且計算出全部數(shù)據(jù)的總和。我們可以將表達式寫為下列的函式,利用code.PushStringStack這個RDLC自定義函式,來讓Sum函式取得所有數(shù)據(jù)。這樣的寫法,就可以將數(shù)據(jù)集中的每一筆數(shù)據(jù)都交由code.PushString處理過一次。

復(fù)制代碼 代碼如下:


=Sum(code.PushString(Fields!Name.Value, Fields!Age.Value), "UserDataSet")


接著看code.PushString這個RDLC自定義函式的內(nèi)部,使用了一個Static的字符串變量,來記錄每一筆數(shù)據(jù)處理之后的結(jié)果。到這邊開發(fā)人員應(yīng)該可以理解,這樣的方式就是在跑循環(huán)處理數(shù)據(jù)。

復(fù)制代碼 代碼如下:


Public Shared _foreachResult As String = String.Empty

Public Shared Function PushString(userName As String, userAge As String) As Integer
    _foreachResult += userName & "(" & userAge & "), "
    Return 0
End Function


當然啦,跑完循環(huán)處理完數(shù)據(jù),最終還是要將數(shù)據(jù)顯示在畫面上。這邊很簡單的就是建立一個code.PopString回傳。

復(fù)制代碼 代碼如下:


Public Shared Function PopString() As String
    Return _foreachResult
End Function


并且將原本的表達式改寫成為:

復(fù)制代碼 代碼如下:


=IIF(Sum(code.PushString(Fields!Name.Value, Fields!Age.Value), "UserDataSet") <> 0, "", code.PopString())


編譯并且執(zhí)行之后,就可以看到在RDLC的文本框里,已經(jīng)正確的顯示了客戶要求的數(shù)據(jù)格式。

.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法

“.NET中RDLC循環(huán)處理數(shù)據(jù)的應(yīng)用方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI