第三篇:CHAR、CODE、CLEAN、TRIM函數
CHAR函數
功能: 将代碼轉換為字符
語法: CHAR(num)
說明:Num是用于轉換的字符代碼,介于 1 到 255 之間。使用的是當前計算機字符集中的字符。其中65—90對應的A—Z,97—122對應a—z,10對應為換行符。
示例:
上圖K列數據采用逗号分隔,看起來不太直觀,采用CHAR可輕松轉換為L列的顯示效果。
L列公式:=SUBSTITUTE(K2,",",CHAR(10))
公式解釋:通過替換字符函數SUBSTITUTE将字符串中的逗号替換為換行符,其中char(10)代表換行符。
CODE函數功能:返回文本字符串中第一個字符的數字代碼,返回的代碼對應于計算機當前使用的字符集。
語法: CODE(text)
說明:text是字符串時,隻返回字符串的首字符對應的代碼,比如code("te")結果為字符t對應的代碼84。code函數與char函數為對應函數,但不是完全對應的,比如數字1,9,10,對應的字符都顯示為空白,而且這種顯示為空白的字符還有很多,最有名的就是63号字符。根據截圖表中數據,63對應的字符為“?”,但其實還有很多code函數取值為63卻不是問号的字符,這方面在《excel函數公式的克星——63号字符,學習函數一定要提前了解!》一文中有專門介紹。
CLEAN函數功能:用于删除文本中不能打印的字符。對從其他應用程序中輸入的文本使用該函數,将删除其中含有當前操作系統無法打印的字符。
語法:CLEAN(text)
說明:text:要進行删除不可打印字符的文本,CLEAN函數常用于從其他程序或網絡導出數據的類似清洗功能,避免數據受不可打印字符影響無法進行一些常規操作。
示例:
表中金額列合計結果為0,是淘寶商家從網站上導出數據後,處理時經常遇到問題。其實就是因為網站上導出的數據包含了不可打印字符,一般就會用到CLEAN函數進行處理。C2單元格公式=CLEAN(B2)*1。這裡*1的作用是将清洗後的數據格式由文本轉換為數值。
另外CLEAN函數用于對字符串進行操作,還可實現下面的效果:
TRIM函數
功能:消除字符串首尾兩端的空格符和字符中間的多個連續空格符,中間空格符保留一個不消除。
語法:TRIM(text)
說明:輸入數據時,有時候會誤在字符串前後輸入一些空格符,由于在前後,一般不太容易被發現,但在一些用到字符串進行比較匹配的函數時,這些誤操作輸入的空格符會匹配不上,導緻最終結果出現問題。
示例:
如圖彙總統計中用的統一公式,下面兩項都正确,但第一項結果明顯不對,原因就是彙總統計中輸入時黃瓜前面誤輸了空格,導緻,無法匹配。修改公式為:=COUNTIF($B$3:$B$6,TRIM(E4)),通過TRIM(E4)消除了E4單元格中誤輸入的空格,就可以與B列名稱匹配成功了。
當在登記表中誤操作輸入空格符時,比如第3項黃瓜後面有空格,結果又不對。這時我們有兩種方法解決,第一種用TRIM函數設輔助列,如下:
用TRIM對B列名稱進行消除收尾空格操作,得到D列無空格名稱列,
修改彙總統計函數中參數由原先的查找B列,改為查找D列,從而避免了空格的影響。
第二種是在統計函數中納入通配符進行匹配,修改采購次數公式為:
=COUNTIF($B$3:$B$6,"*"&TRIM(F4)&"*"),是這類問題的正解。
有時候輸入時把空格給輸入到字符中間了,而TRIM函數又對字符中間的空格沒有辦法,遇到這種情況,可采用字符替換函數SUBSTITUTE将空格消掉得到兩端和中間都沒有空格的字符串輔助列,再進行統計匹配。修改D列公式為:=SUBSTITUTE(B3," ","")G列公式為=COUNTIF(D3:D6,SUBSTITUTE(F4," ","")),這樣能确保匹配成功。
很多人會為了數據對齊美觀,喜歡在名稱字符少的中間輸入空格,雖然在後期處理時是可以解決,但總歸是多了操作,為了對齊名稱,建議通過設置單元格格式進行操作,具體如下:
這時D列數據對齊,而且字符中間實際是沒有空格符的,不會對匹配操作造成影響。
若對本篇4個函數有疑問,請留言交流。
,