• <label id="pxtpz"><meter id="pxtpz"></meter></label>
      1. <span id="pxtpz"><optgroup id="pxtpz"></optgroup></span>

        當前位置:雨林木風下載站 > 辦公軟件教程 > 詳細頁面

        excel公式技巧:從字符串中提取數字——數字位于字符串末尾

        excel公式技巧:從字符串中提取數字——數字位于字符串末尾

        更新時間:2023-12-20 文章作者:未知 信息來源:網絡 閱讀次數:

        Microsoft Excel是Microsoft為使用Windows和Apple Macintosh操作系統的電腦編寫的一款電子表格軟件。直觀的界面、出色的計算功能和圖表工具,再加上成功的市場營銷,使Excel成為最流行的個人計算機數據處理軟件。

        本文研究從字符串開頭提取數字的技術:

        1. 這些數字是連續的

        2. 這些連續的數字位于字符串的末尾

        3. 想要的結果是將這些連續的數字返回到單個單元格

        與上篇文章一樣,對于下面研究的每種解決方案,我們需要在兩種不同的情況下測試其健全性:

        1. 字符串中除末尾外其他地方沒有數字的情況,例如ABC456。

        2. 字符串中除末尾外其他地方也有數字,要么在開頭,要么在中間,例如123ABC456或ABC123DEF456。

        MIN與FIND

        公式1:

        =0+MID(A1,MIN(FIND({0,1,2,3,4,5,6,7,8,9},A1& 1/17)),LEN(A1))

        如果單元格A1中的內容為“ABC456”,那么上述公式1返回“456”。其解析過程如下:

        =0+MID(“ABC456”,MIN(FIND({0,1,2,3,4,5,6,7,8,9},“ABC456” & 1/17)),LEN(“ABC456”))

        在A1后面添加1/17與在其后面添加字符串“0123456789”效果相同,詳見《Excel公式技巧08. 17分之一和其他全數字(pandigitals)》。主要是必須將A1與包含0到9的所有數字的字符串連接起來,以防止MIN函數返回錯誤。因為如果A1不包含0-9的所有數字,那么FIND函數的返回值至少有一個是錯誤值,由于MIN函數不會忽略錯誤值,會導致整個公式的結果也是一個錯誤值。通過首先在A1中的字符串末尾添加一個適當的值(例如1/17、3^45,“0123456789”),可以保證該字符串將包含至少一個0-9中的每個數字(因此FIND函數的所有10個返回值都是非錯誤值),同時通過將字符串放在A1的末尾確保我們不會影響MIN函數所需的輸出。

        這樣,現在上述公式轉換為:

        =0+MID(“ABC456”,MIN(FIND({0,1,2,3,4,5,6,7,8,9},”ABC456″&0.0588235294117647)),LEN(“ABC456”))

        可能你還不知道,在某些公式結構中,MIN函數具有強制返回數組的能力,且無需按Ctrl+Shift+Enter組合鍵。本例就屬于這種情況,因此FIND函數將對傳遞給它的所有10個值進行操作,而不僅僅是對第一個值進行操作。因此,上述公式轉換為:

        =0+MID(“ABC456”,MIN({7,19,13,14,4,5,6,21,11,17}),LEN(“ABC456”))

        MIN函數返回字符串中數字開始的位置4,因此,上述公式轉換為:

        =0+MID(“ABC456”,4,LEN(“ABC456”))

        注意,MID函數(以及RIGHT函數和LEFT函數)具有一些有用的特性,當傳遞的參數num_chars的值大于要提取的實際字符串的長度時不會出錯。也就是說,如果該參數的值將導致全部或部分返回值超出字符串末尾的情況時,則這些函數僅返回從指定位置到字符串末尾的那些字符。這里將參數num_chars的值指定為LEN(A1),因為沒有子字符串的長度會大于字符串自身的情況。這樣,上述公式轉換為:

        =0+MID(“ABC456″,4,6)

        得到結果:

        456

        下面我們看看如果單元格A1中的字符串包含其它數字例如123ABC456,公式1是否有效。此時公式1轉換為:

        =0+MID(“123ABC456“,MIN(FIND({0,1,2,3,4,5,6,7,8,9},”123ABC4560.0588235294117647”)),LEN(A1))

        轉換為:

        =0+MID(“123ABC456“,MIN({10,1,2,3,7,8,9,24,14,20}),LEN(A1))

        轉換為:

        =0+MID(“123ABC456“,1,LEN(“123ABC456“))

        轉換為:

        =0+MID(“123ABC456“,1,9)

        由于字符串中有其它數字的影響,導致找到的傳遞到MID函數的起始位置變化,因此結果為:

        #VALUE!

        LOOKUP與RIGHT

        公式2:

        =-LOOKUP(0,-RIGHT(A1,ROW(INDIRECT(“1:”& LEN(A1)))))

        這個公式與上一篇文章《Excel公式技巧10:從字符串中提取數字——數字位于字符串開頭》中的公式1相似,只是使用RIGHT函數代替了LEFT函數。

        當然,如果單元格A1中的字符串與“JAN18”、“123E4”類似,則不會返回正確的結果,詳細原因參見上篇文章。

        RIGHT、MATCH與ISNUMBER

        公式3:

        =0+RIGHT(A1,MATCH(FALSE,ISNUMBER(0+MID(A1,1+LEN(A1)-ROW(INDIRECT(“1:”& LEN(A1))),1)),0)-1)

        這是一個數組公式。

        仍以單元格A1中的數據為“ABC456”,公式3可轉換為:

        =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-ROW(INDIRECT(“1:”& 6)),1)),0)-1)

        轉換為:

        =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,1+6-{1;2;3;4;5;6},1)),0)-1)

        轉換為(注意,這里是如何將得到的數組顛倒,從而使得從字符串的末尾到開頭逐個獲取字符成為可能):

        =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“ABC456”,{6;5;4;3;2;1},1)),0)-1)

        轉換為:

        =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER(0+{6;5;4;C;B;A}),0)-1)

        通過適當的數學運算(將數組與0相加),強制數字字符轉換成數字:

        =0+RIGHT(“ABC456”,MATCH(FALSE,ISNUMBER({6;5;4;#VALUE!;#VALUE!;#VALUE!}),0)-1)

        ISNUMBER函數忽略傳遞給其參數中的錯誤值:

        =0+RIGHT(“ABC456”,MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

        轉換為:

        =0+RIGHT(“ABC456”,4-1)

        其中的4表示在字符串“”中第一個非數字字符自右向左出現的位置,減1表示數字字符出現的位置:

        =0+RIGHT(“ABC456”,3)

        結果為:

        456

        下面,我們來看看字符串中除末尾以外的數字會不會影響最終的結果。例如如果單元格A1中的數據是“123ABC456”,那么公式3可以轉換為:

        =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+MID(“123ABC456”,1+LEN(“123ABC456”)-ROW(INDIRECT(“1:”& LEN(“123ABC456”))),1)),0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(0+{“6”;”5”;”4”;”C”;”B”;”A”;”3”;”2”;”1”}),0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,MATCH(FALSE,ISNUMBER(6;5;4;#VALUE!; #VALUE!; #VALUE!;3;2;1}),0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,MATCH(FALSE,{TRUE;TRUE;TRUE;FALSE;FALSE;FALSE;TRUE;TRUE;TRUE},0)-1)

        轉換為:

        =0+RIGHT(“ABC456”,4-1)

        其中的4表示在字符串“”中第一個非數字字符自右向左出現的位置,減1表示數字字符出現的位置:

        =0+RIGHT(“ABC456”,3)

        結果為:

        456

        可以看到,由于是從右向左取數,因此在字符串的其它位置存在數字并不會影響結果。

        RIGHT、MATCH與ISERR

        公式4:

        =0+RIGHT(A1,MATCH(1,0+ISERR(0+MID(A1,1+LEN(A1)-ROW(INDIRECT(“1:”& LEN(A1))),1)),0)-1)

        這是一個數組公式。

        以單元格A1中的數據為“123ABC456”,公式4可轉換為:

        =0+RIGHT(“123ABC456”,MATCH(1,0+ISERR(0+{“6″;”5″;”4″;”C”;”B”;”A”;”3″;”2″;”1″}),0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,MATCH(1,0+{FALSE;FALSE;FALSE;TRUE;TRUE;TRUE;FALSE;FALSE;FALSE},0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,MATCH(1,{0;0;0;1;1;1;0;0;0},0)-1)

        轉換為:

        =0+RIGHT(“123ABC456”,4-1)

        轉換為:

        =0+RIGHT(“123ABC456”,3)

        結果為:

        456

        與公式3一樣,字符串中除末尾有數字外其它部位存在數字時不影響結果。


        Excel整體界面趨于平面化,顯得清新簡潔。流暢的動畫和平滑的過渡,帶來不同以往的使用體驗。

        溫馨提示:喜歡本站的話,請收藏一下本站!

        本類教程下載

        系統下載排行

        主站蜘蛛池模板: 亚洲福利视频导航| 久久综合亚洲色HEZYO国产| 日产亚洲一区二区三区| 日韩人妻一区二区三区免费| 亚洲国产精品一区第二页| 成人久久免费网站| 国产亚洲成av片在线观看| 久久久精品免费视频| 亚洲人成网77777亚洲色| 国产一级a毛一级a看免费人娇| 亚洲午夜久久久久久久久电影网 | 美女网站在线观看视频免费的| 亚洲AV成人潮喷综合网| 中文字幕版免费电影网站| 亚洲成AV人片一区二区密柚| 一区二区三区观看免费中文视频在线播放 | 国产精品久久亚洲不卡动漫| 在线观看AV片永久免费| 亚洲乱色熟女一区二区三区蜜臀| 日韩免费高清视频| 免费无遮挡无码视频在线观看| 久久久久国产成人精品亚洲午夜 | 国产精品亚洲综合久久 | 亚洲成a人片在线观看无码 | 91亚洲国产成人久久精品| 成人男女网18免费视频| 免费大片黄在线观看| 亚洲精品卡2卡3卡4卡5卡区| 97公开免费视频| 亚洲日产乱码一二三区别| 亚洲美女在线国产| 久久A级毛片免费观看| 亚洲色丰满少妇高潮18p| 亚洲色偷偷综合亚洲AV伊人| 久久免费精品视频| 亚洲中文无码mv| 国产亚洲精aa成人网站| 国产精品成人免费福利| 羞羞漫画登录页面免费| 亚洲四虎永久在线播放| 卡一卡二卡三在线入口免费|