Antworten:
Stellen Sie zunächst sicher, dass die erforderliche Nummer von Anfang oder Ende an ein gültiger Index für die Zeichenfolge ist, und verwenden Sie dann einfach die Array-Indexnotation. Verwenden Sie len(s)
diese Option, um die Zeichenfolgenlänge abzurufen
>>> s = "python"
>>> s[3]
'h'
>>> s[6]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: string index out of range
>>> s[0]
'p'
>>> s[-1]
'n'
>>> s[-6]
'p'
>>> s[-7]
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
IndexError: string index out of range
>>>
s[-5]
kann funktionieren, s[-6]
würde aber einen Indexfehler außerhalb des Bereichs beanstanden? So neugierig auf die Implementierung im String-Objekt in Python.
In [1]: x = "anmxcjkwnekmjkldm!^%@(*)#_+@78935014712jksdfs"
In [2]: len(x)
Out[2]: 45
Für positive Indexbereiche für x liegt der Wert zwischen 0 und 44 (dh Länge - 1).
In [3]: x[0]
Out[3]: 'a'
In [4]: x[45]
---------------------------------------------------------------------------
IndexError Traceback (most recent call last)
/home/<ipython console> in <module>()
IndexError: string index out of range
In [5]: x[44]
Out[5]: 's'
Für den negativen Index reicht der Index von -1 bis -45
In [6]: x[-1]
Out[6]: 's'
In [7]: x[-45]
Out[7]: 'a
Bei negativem Index gibt negativ [Länge -1], dh der letzte gültige Wert des positiven Index, das zweite Listenelement an, wenn die Liste in umgekehrter Reihenfolge gelesen wird.
In [8]: x[-44]
Out[8]: 'n'
Andere, Indexbeispiele,
In [9]: x[1]
Out[9]: 'n'
In [10]: x[-9]
Out[10]: '7'
Frühere Antworten beziehen sich ASCII character
auf einen bestimmten Index.
Es ist ein bisschen mühsam, Unicode character
in Python 2 einen bestimmten Index zu erhalten.
ZB mit s = '한국中国にっぽん'
dem ist <type 'str'>
,
__getitem__
z. B. s[i]
führt Sie nicht dorthin, wo Sie es wünschen. Es wird so etwas wie ausspucken �
. (Viele Unicode-Zeichen sind mehr als 1 Byte, __getitem__
in Python 2 wird sie jedoch um 1 Byte erhöht.)
In diesem Python 2-Fall können Sie das Problem durch Decodieren lösen:
s = '한국中国にっぽん'
s = s.decode('utf-8')
for i in range(len(s)):
print s[i]
Python.org hat einen ausgezeichneten Abschnitt Strings hier . Scrollen Sie nach unten zu "Slice Notation".
Dies sollte die Punkte weiter verdeutlichen:
a = int(raw_input('Enter the index'))
str1 = 'Example'
leng = len(str1)
if (a < (len-1)) and (a > (-len)):
print str1[a]
else:
print('Index overflow')
Eingang 3 Ausgang m
Eingang -3 Ausgang p
Ich denke, das ist klarer als es in Worten zu beschreiben
s = 'python'
print(len(s))
6
print(s[5])
'n'
print(s[len(s) - 1])
'n'
print(s[-1])
'n'