次の python スクリプトがあるとします。
# dedupe.py
import re
def dedupe_whitespace(s,spacechars='\t '):
"""Merge repeated whitespace characters.
Example:
>>> dedupe_whitespace(r"Green\t\tGround") # doctest: +REPORT_NDIFF
'Green\tGround'
"""
for w in spacechars:
s = re.sub(r"("+w+"+)", w, s)
return s
この関数は、Python インタープリター内で意図したとおりに機能します。
$ python
>>> import dedupe
>>> dedupe.dedupe_whitespace('Purple\t\tHaze')
'Purple\tHaze'
>>> print dedupe.dedupe_whitespace('Blue\t\tSky')
Blue Sky
ただし、結果の文字列と比較する前にタブ文字がスペースに変換されるため、doctest の例は失敗します。
>>> import doctest, dedupe
>>> doctest.testmod(dedupe)
与える
Failed example:
dedupe_whitespace(r"Green Ground") #doctest: +REPORT_NDIFF
Differences (ndiff with -expected +actual):
- 'Green Ground'
? -
+ 'Green Ground'
テスト結果の比較が適切に実行されるように、doctest ヒアドキュメント文字列でタブ文字をエンコードするにはどうすればよいですか?