<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 225  文章 - 98  trackbacks - 0
    <2012年9月>
    2627282930311
    2345678
    9101112131415
    16171819202122
    23242526272829
    30123456

    隨筆分類

    相冊

    報表工具廠商們

    搜索

    •  

    最新評論

    閱讀排行榜


    使用FineReport經常會遇到在設計中要取兩個字符之間的數據或者文本的問題。在此貢獻一些公式給大家。

    寫過代碼的都知道想到的是用substr或者split函數來做,但是仔細研究一下就會發現substr只能解決取從第幾個字符開始的n個字符,而split是返回的用分隔符分割的字符串,沒有選擇性的截取,后來找了一下,發現原來有這種算法,例子中說的是在excel中的方法,fr兼容excel所以這一點不用擔心。

    有時需要從包含分隔符號的字符串中提取子字符串,例如Excel工作表的某列中包含類似“200-GH11301-11TB5”的文本字符串,該字符串被兩個相同的分隔符號“-”分成三部分,且每部分的字符數不固定,現在需要提取其中的第2部分內容“GH11301"。這時可以使用下面的公式,假如原字符串位于A1單元格中,在B1單元格中輸入如下公式:

    =MID(LEFT(A1,FIND("`",SUBSTITUTE(A1,"-","`",2))-1),FIND("`",SUBSTITUTE(A1,"-","`",1))+1,LEN(A1))

    公式說明:本例用SUBSTITUTE函數將兩個分隔符號“-”替換為“`”,“`”符號位于數字“1”鍵的左側,也可改為字符串中沒有出現的其他特殊符號。然后用FIND函數查找第二個“`”出現的位置并用LEFT函數去掉第二個“`”后面的部分,最后用MID函數提取所需內容。由于MID函數的第三個參數“LEN(A1)”大于所提取文本的字符數,因而本公式適用于各部分長度不固定的字符串。

          也可使用下面的公式:

    =TRIM(MID(SUBSTITUTE(A1,"-",REPT(" ",LEN(A1))),LEN(A1),LEN(A1)))

    公式說明:REPT(" ",LEN(A1))產生一個與原字符串長度相同的空格字符串,用SUBSTITUTE函數將其替換各分隔符號,這樣所需提取文本的前后就都包含了與原字符串長度相同的空格字符串,再用MID函數進行截取,截取后的字符串前后都包含一些空格,最后用TRIM函數去掉這些空格即得到所需文本。

    本例原字符串中有2個分隔符號,第一部分有3個字符,第二部分有7個字符,第三部分有5個字符,字符串總長度LEN(A1)=17,MID函數截取后“GH11301”的前面就有4(3+17-17+1)個空格,后面就有6(17-4-7)個空格。
        
        如果字符串中包含更多的分隔符號,如“1130-80-F030305-5TB1-T(40)”,要提取各部分內容,可以將公式改為:

    提取第一部分:

    =TRIM(MID(SUBSTITUTE(A1,"-",REPT(" ",LEN(A1))),1,LEN(A1)))

    或者直接用公式:

    =LEFT(A1,FIND("-",A1)-1)

    提取其他部分,如第3部分“F030305”:

    =TRIM(MID(SUBSTITUTE(A1,"-",REPT(" ",LEN(A1))),2*LEN(A1),LEN(A1)))

    本例中提取字符串中的第3部分,公式中用紅色標識的數字為“2”,如果是第N部分,則為N-1。



    了解Java報表工具就從這里開始
    posted on 2012-09-06 23:46 season 閱讀(930) 評論(0)  編輯  收藏 所屬分類: Java報表—技術知識
    主站蜘蛛池模板: a级毛片免费全部播放无码| 极品美女一级毛片免费| 99精品视频在线观看免费播放| 亚洲区小说区图片区| 美美女高清毛片视频黄的一免费| 国产美女无遮挡免费视频 | 可以免费看的卡一卡二| 亚洲春色另类小说| 美女视频黄是免费的网址| 亚洲深深色噜噜狠狠网站| 美女黄网站人色视频免费国产| 亚洲欧洲日韩国产一区二区三区| 97在线线免费观看视频在线观看 | 久久精品a一国产成人免费网站| 亚洲AV色吊丝无码| 免费黄色app网站| 青青草国产免费国产是公开 | 亚洲免费一区二区| 国产无遮挡色视频免费观看性色| 亚洲女同成av人片在线观看| 999久久久免费精品播放| 亚洲最大黄色网站| 国产网站免费观看| 中文字幕a∨在线乱码免费看| 无码乱人伦一区二区亚洲| 日本高清在线免费| 亚洲精品GV天堂无码男同| 天堂亚洲免费视频| 日本免费在线观看| 亚洲日韩一中文字暮| 久久久久久亚洲精品不卡| 91精品手机国产免费| 国产亚洲人成在线播放| 亚洲国产a∨无码中文777| 欧美男同gv免费网站观看| 国产精品亚洲精品日韩动图| 国产∨亚洲V天堂无码久久久| 亚洲免费综合色在线视频| 一级做a爰性色毛片免费| 亚洲男人的天堂在线播放| 精品免费国产一区二区三区|