iOS開發(fā)之?dāng)?shù)字每隔3位用逗號分隔
demo: 源碼下載:http://xiazai.jb51.net/201709/yuanma/DMLimtDemo_jb51.rar
之前做電商類APP時(shí),針對稍大的金額展示時(shí),需要每隔千位添加逗號便于用戶識別。
邏輯比較簡單,這里按需要寫了一個(gè)可選前后綴的一個(gè)轉(zhuǎn)換方法:
#import "DMViewController.h" @interface DMViewController () @property (weak, nonatomic) IBOutlet UITextField *titleText; @property (weak, nonatomic) IBOutlet UILabel *numLab; @end @implementation DMViewController - (IBAction)tapButtonAction:(id)sender { UIButton *tempBut = (UIButton *)sender; if (tempBut.isSelected) { tempBut.selected = NO; _numLab.text = @"label"; } else { tempBut.selected = YES; NSString *newNumber = [self separateNumberUseCommaWith:_titleText.text]; _numLab.text = newNumber; } } // 將數(shù)字轉(zhuǎn)為每隔3位整數(shù)由逗號“,”分隔的字符串 - (NSString *)separateNumberUseCommaWith:(NSString *)number { // 前綴 NSString *prefix = @"¥"; // 后綴 NSString *suffix = @"元"; // 分隔符 NSString *divide = @","; NSString *integer = @""; NSString *radixPoint = @""; BOOL contains = NO; if ([number containsString:@"."]) { contains = YES; // 若傳入浮點(diǎn)數(shù),則需要將小數(shù)點(diǎn)后的數(shù)字分離出來 NSArray *comArray = [number componentsSeparatedByString:@"."]; integer = [comArray firstObject]; radixPoint = [comArray lastObject]; } else { integer = number; } // 將整數(shù)按各個(gè)字符為一組拆分成數(shù)組 NSMutableArray *integerArray = [[NSMutableArray alloc] init]; for (int i = 0; i < integer.length; i ++) { NSString *subString = [integer substringWithRange:NSMakeRange(i, 1)]; [integerArray addObject:subString]; } // 將整數(shù)數(shù)組倒序每隔3個(gè)字符添加一個(gè)逗號“,” NSString *newNumber = @""; for (NSInteger i = 0 ; i < integerArray.count ; i ++) { NSString *getString = @""; NSInteger index = (integerArray.count-1) - i; if (integerArray.count > index) { getString = [integerArray objectAtIndex:index]; } BOOL result = YES; if (index == 0 && integerArray.count%3 == 0) { result = NO; } if ((i+1)%3 == 0 && result) { newNumber = [NSString stringWithFormat:@"%@%@%@",divide,getString,newNumber]; } else { newNumber = [NSString stringWithFormat:@"%@%@",getString,newNumber]; } } if (contains) { newNumber = [NSString stringWithFormat:@"%@.%@",newNumber,radixPoint]; } if (![prefix isEqualToString:@""]) { newNumber = [NSString stringWithFormat:@"%@%@",prefix,newNumber]; } if (![suffix isEqualToString:@""]) { newNumber = [NSString stringWithFormat:@"%@%@",newNumber,suffix]; } return newNumber; } @end
示意圖:
總結(jié)
以上所述是小編給大家介紹的iOS開發(fā)之?dāng)?shù)字每隔3位用逗號分隔,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
iOS實(shí)現(xiàn)帶指引線的餅狀圖效果(不會重疊)
餅狀圖對大家來說應(yīng)該都不陌生,下面這篇文章主要給大家介紹了關(guān)于iOS實(shí)現(xiàn)帶指引線的餅狀圖效果(不會重疊)的相關(guān)資料,文章通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-04-04iOS中利用UIBezierPath + CAAnimation實(shí)現(xiàn)心跳動(dòng)畫效果
這篇文章主要給大家介紹了關(guān)于iOS中利用UIBezierPath + CAAnimation實(shí)現(xiàn)心跳動(dòng)畫效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的日常開發(fā)具有一定的參考學(xué)習(xí),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10簡單談?wù)凜ore Animation 動(dòng)畫效果
下面小編就為大家?guī)硪黄唵握務(wù)凜ore Animation 動(dòng)畫效果。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06iOS開發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決
大家都知道WebViewJavascriptBridge它主要幫助我們優(yōu)雅的實(shí)現(xiàn)OC與JS的交互,下面這篇文章主要給大家介紹了關(guān)于iOS開發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決方法,需要的朋友可以參考借鑒,下面來一起看看吧。2017-10-10iOS適配iPhone XS、 iPhone XS Max and iPhone XR的方法淺析
這篇文章主要給大家介紹了關(guān)于iOS適配iPhone XS、 iPhone XS Max and iPhone XR的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-09-09通過UIKit坐標(biāo)系來全面掌握iOS中的UIScrollView組件
iOS開發(fā)套件中的UIScrollView組件十分強(qiáng)大,不僅是滾動(dòng),縮放操作也能夠控制自如,其核心當(dāng)然是坐標(biāo)軸上的控制,下面就通過UIKit坐標(biāo)系來全面掌握iOS中的UIScrollView組件2016-05-05在iOS App中實(shí)現(xiàn)地理位置定位的基本方法解析
這篇文章主要介紹了在iOS App中實(shí)現(xiàn)地理位置定位的基本方法解析,包括獲取當(dāng)前位置和計(jì)算兩點(diǎn)間距離等基本功能的實(shí)現(xiàn),需要的朋友可以參考下2016-05-05