Wyświetlam odległość z jednym miejscem po przecinku i chciałbym usunąć ten dziesiętny, jeśli jest równy 0 (np. 1200,0 km), jak mogę to zrobić szybko? Wyświetlam ten numer w ten sposób:
let distanceFloat: Float = (currentUser.distance! as NSString).floatValue
distanceLabel.text = String(format: "%.1f", distanceFloat) + "Km"
ios
swift
floating-point
Kali Aney
źródło
źródło
Odpowiedzi:
Swift 3/4:
var distanceFloat1: Float = 5.0 var distanceFloat2: Float = 5.540 var distanceFloat3: Float = 5.03 extension Float { var clean: String { return self.truncatingRemainder(dividingBy: 1) == 0 ? String(format: "%.0f", self) : String(self) } } print("Value \(distanceFloat1.clean)") // 5 print("Value \(distanceFloat2.clean)") // 5.54 print("Value \(distanceFloat3.clean)") // 5.03
Swift 2 (oryginalna odpowiedź)
let distanceFloat: Float = (currentUser.distance! as NSString).floatValue distanceLabel.text = String(format: distanceFloat == floor(distanceFloat) ? “%.0f" : "%.1f", distanceFloat) + "Km"
Lub jako rozszerzenie:
extension Float { var clean: String { return self % 1 == 0 ? String(format: "%.0f", self) : String(self) } }
źródło
distanceFloat = floor(distanceFloat * 10) / 10
a potem działało idealnie, dzięki :)Użyj NSNumberFormatter:
let formatter = NumberFormatter() formatter.minimumFractionDigits = 0 formatter.maximumFractionDigits = 2 // Avoid not getting a zero on numbers lower than 1 // Eg: .5, .67, etc... formatter.numberStyle = .decimal let nums = [3.0, 5.1, 7.21, 9.311, 600.0, 0.5677, 0.6988] for num in nums { print(formatter.string(from: num as NSNumber) ?? "n/a") }
Zwroty:
3
5.1
7.21
9.31
600
0.57
0,7
źródło
let formatter = NumberFormatter() formatter.minimumFractionDigits = 0 formatter.maximumFractionDigits = 1 statLabel.text = formatter.string(from: value as NSNumber) ?? "n/a"
formatter.numberStyle = .decimal
.decimal
numeru NumberStyle poniżej 1 wyświetlą się bez zera. Np .: .5, .78, itd ... Edytujemy teraz odpowiedź.extension
to potężny sposób, aby to zrobić.Rozszerzenie :
Kod Swift 2 (nie Swift 3 ani nowszy):
extension Float { var cleanValue: String { return self % 1 == 0 ? String(format: "%.0f", self) : String(self) } }
Użycie :
var sampleValue: Float = 3.234 print(sampleValue.cleanValue)
sampleValue = 3.0 print(sampleValue.cleanValue)
sampleValue = 3 print(sampleValue.cleanValue)
Przykładowy plik Playground jest tutaj .
źródło
Aktualizacja zaakceptowanej odpowiedzi dla Swift 3 :
extension Float { var cleanValue: String { return self.truncatingRemainder(dividingBy: 1) == 0 ? String(format: "%.0f", self) : String(self) } }
użycie byłoby po prostu:
let someValue: Float = 3.0 print(someValue.cleanValue) //prints 3
źródło
Aby sformatować go na ciąg, postępuj zgodnie z tym wzorcem
let aFloat: Float = 1.123 let aString: String = String(format: "%.0f", aFloat) // "1" let aString: String = String(format: "%.1f", aFloat) // "1.1" let aString: String = String(format: "%.2f", aFloat) // "1.12" let aString: String = String(format: "%.3f", aFloat) // "1.123"
Aby rzucić to na Int, postępuj zgodnie z tym wzorcem
let aInt: Int = Int(aFloat) // "1"
Gdy używasz
String(format:
inicjatora, Swift automatycznie zaokrągli ostatnią cyfrę w razie potrzeby na podstawie następującej liczby.źródło
Możesz użyć rozszerzenia, jak już wspomniano, to rozwiązanie jest jednak trochę krótsze:
extension Float { var shortValue: String { return String(format: "%g", self) } }
Przykładowe użycie:
var sample: Float = 3.234 print(sample.shortValue)
źródło
0.00000001
. Zobacz dokumentację% g na pubs.opengroup.org/onlinepubs/009695399/functions/printf.html : „ Zastosowany styl zależy od przekonwertowanej wartości; styl e (lub E) powinien być używany tylko wtedy, gdy wykładnik będący wynikiem takiej konwersji jest mniejsza niż -4 lub większa lub równa precyzji. ”W Swift 4 spróbuj tego.
extension CGFloat{ var cleanValue: String{ //return String(format: 1 == floor(self) ? "%.0f" : "%.2f", self) return self.truncatingRemainder(dividingBy: 1) == 0 ? String(format: "%.0f", self) : String(format: "%.2f", self)// } }
// Jak używać - jeśli wprowadzisz więcej niż dwa znaki po (.) Punkcie, automatycznie przycina ostatni znak i wyświetla tylko dwa znaki po punkcie.
let strValue = "32.12" print(\(CGFloat(strValue).cleanValue)
źródło
1.1
: wyjście będzie"1.10"
.NSNumberFormatter to Twój przyjaciel
let distanceFloat: Float = (currentUser.distance! as NSString).floatValue let numberFormatter = NSNumberFormatter() numberFormatter.positiveFormat = "###0.##" let distance = numberFormatter.stringFromNumber(NSNumber(float: distanceFloat))! distanceLabel.text = distance + " Km"
źródło
Formatowanie z maksymalną liczbą cyfr po przecinku, bez końcowych zer
Ten scenariusz jest dobry, gdy wymagana jest niestandardowa precyzja wyjściowa. To rozwiązanie wydaje się mniej więcej tak szybkie, jak rozwiązanie NumberFormatter + NSNumber firmy MirekE , ale jedną z korzyści może być to, że unikamy tutaj NSObject.
extension Double { func string(maximumFractionDigits: Int = 2) -> String { let s = String(format: "%.\(maximumFractionDigits)f", self) var offset = -maximumFractionDigits - 1 for i in stride(from: 0, to: -maximumFractionDigits, by: -1) { if s[s.index(s.endIndex, offsetBy: i - 1)] != "0" { offset = i break } } return String(s[..<s.index(s.endIndex, offsetBy: offset)]) } }
(działa również z
extension Float
typem macOS, ale nie działaFloat80
)Sposób użycia:
myNumericValue.string(maximumFractionDigits: 2)
lubmyNumericValue.string()
Wyjście dla
maximumFractionDigits: 2
:źródło
Swift 5 for Double to to samo, co odpowiedź @ Frankie na float
var dec: Double = 1.0 dec.clean // 1
na rozszerzenie
extension Double { var clean: String { return self.truncatingRemainder(dividingBy: 1) == 0 ? String(format: "%.0f", self) : String(self) } }
źródło
Oto pełny kod.
let numberA: Float = 123.456 let numberB: Float = 789.000 func displayNumber(number: Float) { if number - Float(Int(number)) == 0 { println("\(Int(number))") } else { println("\(number)") } } displayNumber(numberA) // console output: 123.456 displayNumber(numberB) // console output: 789
Oto najważniejsze szczegółowe omówienie linii.
func displayNumber(number: Float) {
Int(number)
.Float(Int(number))
.number - Float(Int(number))
if number - Float(Int(number)) == 0
Treść instrukcji if i else nie wymaga wyjaśnienia.
źródło
String
a zamiastprintln(result)
doreturn result
. Mam nadzieję, że to pomoże!Prosty :
Int(floor(myFloatValue))
źródło
To też może być pomocne.
extension Float { func cleanValue() -> String { let intValue = Int(self) if self == 0 {return "0"} if self / Float (intValue) == 1 { return "\(intValue)" } return "\(self)" } }
Stosowanie:
let number:Float = 45.23230000 number.cleanValue()
źródło
Może
stringByReplacingOccurrencesOfString
mógłby ci pomóc :)let aFloat: Float = 1.000 let aString: String = String(format: "%.1f", aFloat) // "1.0" let wantedString: String = aString.stringByReplacingOccurrencesOfString(".0", withString: "") // "1"
źródło
1.05
wykonajString(format: "%.1f", aFloat)
najpierw będzie1.0
, działa. jeśli1.05
wykonanieString(format: "%.2f", aFloat)
będzie1.05
, a niż powinno to zrobićstringByReplacingOccurrencesOfString(".00"...)