Hintergrund
Ich habe eine Zeichenfolge in Python, die ich in eine Ganzzahl konvertieren möchte. Normalerweise würde ich nur verwenden int
:
>>> int("123")
123
Leider ist diese Methode nicht sehr robust, da nur übereinstimmende Zeichenfolgen akzeptiert werden -?[0-9]+
(nachdem alle führenden oder nachfolgenden Leerzeichen entfernt wurden). Beispielsweise kann es keine Eingabe mit einem Dezimalpunkt verarbeiten:
>>> int("123.45")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: '123.45'
Und damit kann es sicher nicht umgehen:
>>> int("123abc?!")
Auf der anderen Seite kann genau dieses Verhalten in Perl, PHP und sogar im bescheidenen QBasic ohne viel Aufhebens beobachtet werden:
INT(VAL("123abc")) ' 123
Frage
Hier ist meine kürzeste Anstrengung bei dieser "Verallgemeinerung int
" in Python. Es sind 50 Bytes, vorausgesetzt, die ursprüngliche Zeichenfolge befindet sich in s
und das Ergebnis sollte enden in i
:
n="";i=0
for c in s:
n+=c
try:i=int(n)
except:0
Ziemlich einfach, aber das try
/ except
bit ist hässlich und lang. Gibt es eine Möglichkeit, es zu verkürzen?
Einzelheiten
Die Antworten müssen alle folgenden Schritte ausführen:
- Beginnen Sie mit einem String in
s
; ende mit seinem ganzzahligen Wert ini
. - Die Ganzzahl ist der erste Ziffernlauf in der Zeichenfolge. Alles danach wird ignoriert, einschließlich anderer Ziffern, wenn sie nach Nicht-Ziffern kommen.
- Führende Nullen in der Eingabe sind gültig.
- Jede Zeichenfolge, die nicht mit einer gültigen Ganzzahl beginnt, hat den Wert von
0
.
Die folgenden Funktionen werden bevorzugt , sind jedoch nicht erforderlich:
- Ein einzelnes
-
Vorzeichen unmittelbar vor den Ziffern macht die Ganzzahl negativ. - Ignoriert Leerzeichen vor und nach der Nummer.
- Funktioniert genauso gut in Python 2 oder 3.
(Hinweis: Mein obiger Code erfüllt alle diese Kriterien.)
Testfälle
"0123" -> 123
"123abc" -> 123
"123.45" -> 123
"abc123" -> 0
"-123" -> -123 (or 0 if negatives not handled)
"-1-2" -> -1 (or 0 if negatives not handled)
"--1" -> 0
"" -> 0
"12abc3"
geben?12
- es ist analog zum"123.45"
Fall.(lambda(x)(or(parse-integer x :junk-allowed t)0))
(Common Lisp, 49 Byte) - Wird nur als Kommentar gepostet, da es integriert ist.:junk-allowed
--ha, das ist großartig! Ich hätte dies zu einer allgemeinen Golfherausforderung gemacht, wenn die Antwort in vielen Sprachen nicht trivial gewesen wäre. Aber danke für das Lisp. : ^)Antworten:
40 Bytes
und Sie können Negative für 8 Zeichen mehr machen:
quelle
import re;i=int((re.findall("^-?\d+",s)+[0])[0])
funktioniert für 48 Bytes.Python
2, 47, 46Es ist nicht so kurz wie die Verwendung von Regex, aber ich fand es unterhaltsam dunkel.
-1 aufgrund von KSab -
str
mit einigen großen Ganzzahlen funktioniert besser als der Repr-Operator, da er keinL
am Ende setzt.quelle
str(1<<68)
im lstrip