I have a string that has two "0" (str) in it and I want to remove only the "0" (str) at index 4
I have tried calling.replace but obviously that removes all "0", and I cannot find a function that will remove the char at position 4 for me.
Anyone have a hint for me?
使用切片,重建字符串减去要删除的索引:
newstr = oldstr[:4] + oldstr[5:]
as a sidenote, replace
doesn't have to move all zeros. If you just want to remove the first specify count
to 1:
'asd0asd0'.replace('0','',1)
Out:
'asdasd0'
This is my generic solution for any string s
and any index i
:
def remove_at(i, s):
return s[:i] + s[i+1:]
另一种选择,使用列表理解和连接:
''.join([_str[i] for i in xrange(len(_str)) if i != 4])
Slicing works (and is the preferred approach), but just an alternative if more operations are needed (but then converting to a list wouldn't hurt anyway):
>>> a = '123456789'
>>> b = bytearray(a)
>>> del b[3]
>>> b
bytearray(b'12356789')
>>> str(b)
'12356789'
rem = lambda x, unwanted : ''.join([ c for i, c in enumerate(x) if i != unwanted])
rem('1230004', 4)
'123004'
Try this code:
s = input()
a = int(input())
b = s.replace(s[a],'')
print(b)
def remove_char(input_string, index):
first_part = input_string[:index]
second_part - input_string[index+1:]
return first_part + second_part
s = 'aababc'
index = 1
remove_char(s,index)
ababc
zero-based indexing
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.