如何使用Python或GREL向字符串添加数字

时间:2017-05-04 14:31:55

标签: python openrefine grel

我在需要操作的列中有 > 4000 数字。 它们看起来像这样: 040 413 560 89或0361 223240

我如何将其置于以下格式: +49(040)41356089或+49(0361)223240

他们都需要使用相同的国家/地区拨号代码 +49 ,然后将相应的区号放入括号中, 部分已经采用正确的格式。

3 个答案:

答案 0 :(得分:0)

我们可以将字符串分成几组:

>>> groups = '040 413 560 89'.split()
>>> groups
['040', '413', '560', '89']

我们可以对组进行切片,并分配给变量,也将后面的组连接成一个字符串:

>>> city, number = groups[0], ''.join(groups[1:])
>>> city, number
('040', '41356089')

我们可以格式化一个新字符串:

>>> '+49 ({}) {}'.format(city, number)
'+49 (040) 41356089'

我们可以检查号码是否已经以+开头:

>>> '+49 (040) 41356089'.startswith('+')
True

答案 1 :(得分:-1)

这样做:

ls_alreadycorrected = ['(',')','+49']
str_in = '040 413 560 89' #or apply to list

for flag in ls_alreadycorrected:
    if flag not in str_in:
        how_many_spaces = str_in.count(' ')
        if how_many_spaces > 2:
            str_in = str_in.replace(' ','')
            str_out = '+049'+' ' + '(' + str_in[:3] + ') ' + str_in[-8:]
        else:
            str_in = str_in.replace(' ','')
            str_out = '+049'+' ' + '(' + str_in[:4] + ') ' + str_in[-6:]

这只是给你的电话号码类型。对于数字列表,请将其置于顶部而不是str_in

for number in list_of_numbers:
    str_in = number

干杯

答案 2 :(得分:-2)

你可以这样做。

phone  = "456789"
cod = 123

final = str(cod) + phone

结果为"123456789"