我真搞不懂为什么这不管用。我要做的就是删除zwsp (u200b),以及从文件中读取的内容中的换行符和额外空格。
最终,我想把它写到一个新的文件中,这个文件我有功能,只是还没有达到预期的格式。
我的输入(包含zwsp / u200b的短测试文件)由以下内容组成:
Australia 1975
Adelaide 2006 23,500
Brisbane (Logan) 2006 29,700
Brisbane II (North Lakes) 2016 29,000
Austria 1977
Graz 1989 26,100
Innsbruck 2000 16,000
Klagenfurt 2008 27,000
我的代码如下:
input_file = open('/home/me/python/info.txt', 'r')
file_content = input_file.read()
input_file.close()
output_nospace = file_content.replace('\u200b' or '\n' or ' ', '')
print(output_nospace)
f = open('nospace_u200b.txt', 'w')
f.write(output_nospace)
f.close()
然而,这并不像我所期望的那样有效。
虽然它删除了u200b,但它不删除换行符或空格。我必须通过检查作为脚本一部分产生的输出文件来测试是否没有u200b。
如果我删除其中一个操作,例如/u200b,如下所示:
output_nospace = file_content.replace('\n' or ' ', '')
...then非常肯定,结果文件没有换行符或空格,但u200b仍然如出一辙。回到本文顶部描述的原稿,它不会删除u200b、换行符和空格。
有人能告诉我我做错了什么吗?你能像这样链表操作吗?我怎么才能让这个起作用?
谢谢。
发布于 2017-11-25 10:26:11
正如@twotwo-2所指出的,.replace链的以下实现解决了这个问题。
output_nospace = \
file_content.replace('\u200b', '').replace('\n', '').replace(' ', '')
非常感谢你为我指明了正确的方向。:)
发布于 2017-11-25 00:16:04
像"a或b或c“这样的代码的结果仅仅是Python认为不为false的a、b或c的第一件事(None、0、"”、[]和False是一些假值)。在这种情况下,结果是第一个值,zwsp字符。它并不表示要用‘“替换a或b或c;替换代码根本没有通知您使用的是’或‘。但是,您可以像这样链式替换: s.replace('a','').replace('b','').replace('c',‘’)。(此外,在这里,替换是字符串操作,而不是列表操作。)
基于这个问题,我建议提供一个类似learnpython.org的教程。Python或其他编程语言中的语句与人类语言语句的不同之处在于,当您刚开始工作时,您可能会感到困惑。
https://stackoverflow.com/questions/47481382
复制相似问题