][1]
[]内的文字新建一行秒自动对齐[]右边的文字。
如果一行内 只有一个[],一个中文占2个空格,英文占一个,就能做到,但如果出现多个[]就想不到了。
请教用python处理这样的问题应该怎么做呢?
谢谢!!
ps:[]内的字符不单一,有的是[F],有的可能是[Fm]、[Fmaj7]多个字符。
另一个适应型更强的方法:
outputChords = ""
outputLyrics = ""
inBracket = Falsefor i in range(len(line)):
if line[i] == '[': inBracket = True outputChords = outputChords + " " * (max(0, len(outputLyrics.encode('gbk')) - len(outputChords.encode('gbk')))) elif inBracket and line[i] == ']': inBracket = False elif inBracket and line[i] == '#': pass elif inBracket and str.isupper(line[i]): outputChords = outputChords + line[i] elif inBracket: # DONT TRANSPOSE AND PUT IN OUTPUTCHORDS outputChords = outputChords + line[i] else: outputLyrics = outputLyrics + line[i]
python3
设置字体为 等宽字体
>>> s='[F]内的文字新建一行秒自动对齐[C]右边的文字'
>>> import re
>>> ptn=re.compile(r'\[([^]]+)\]([^[]+)')
>>> ss='';t=''
>>> for x,y in ptn.findall(s):
ss+=('{:<%d}'% len(bytes(y,'gbk'))).format(x)
t+=y
>>> print(ss,t,sep='\n')
F C
内的文字新建一行秒自动对齐右边的文字