Don't use a string, use something mutable like bytearray:
#!/usr/bin/python
s = bytearray("my dog has fleas")
for n in xrange(len(s)):
s[n] = chr(s[n]).upper()
print s
Results in:
MY DOG HAS FLEAS
Edit:
Since this is a bytearray
, you aren't (necessarily) working with characters. You're working with bytes. So this works too:
s = bytearray("x81x82x83")
for n in xrange(len(s)):
s[n] = s[n] + 1
print repr(s)
gives:
bytearray(b'x82x83x84')
If you want to modify characters in a Unicode string, you'd maybe want to work with memoryview
, though that doesn't support Unicode directly.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…