去哪——身份证分组

18位身份证的编码规则是:
前1、2位数字表示:所在省(直辖市、自治区)的代码
第3、4位数字表示:所在地级市(自治州)的代码
第5、6位数字表示:所在区(县、自治县、县级市)的代码;
第7—14位数字表示:出生年、月、日;
第15、16位数字表示:所在地的派出所的代码;
第17位数字表示性别:奇数表示男性,偶数表示女性;
第18位数字是校检码,用来检验身份证的正确性。
用户在输入身份证的过程中经常会输入错误,为了方便用户正确输入需要在输入过程中对用户的输入按照 6+8+4 的格式进行分组,实现一个方法接收输入过程中的身份证号,返回分组后的字符。

输入描述:

输入数据有多行,每一行是一个输入过程中的身份证号

输出描述:

分组后的字符串
示例1

输入

5021
502104 198803
5021041988033084
502104198803308324

输出

5021
502104 198803
502104 19880330 84
502104 19880330 8324
1.解决如何用Python多行输入;
2.strip('?')只删除字符串首尾的对应字符,不删除字符串中的,当'?'为空时,默认删除空白符,s.lstrip(): 删除s字符串中开头处,
s.rstrip(): 删除s字符串中结尾处;
3.注意input()和sys.stdin.readline()的区别:sys.stdin.readline( )会将标准输入全部获取,包括末尾的'\n',因此用len计算长度时是把换行符'\n'算进去了的,但是input( )获取输入时返回的结果是不包含末尾的换行符'\n'的。
IDs=[]
while 1:
    Id=input()
    if Id.strip()=='':
        break
    IDs.append(Id)
    
for i in IDs:
	i=i.replace(' ','')
	if len(i)<=6:
		print(i)
	elif len(i)<14:
		print(i[:6]+' '+i[6:])
	else:print(i[:6]+' '+i[6:14]+' '+i[14:])
'''上述在本地IDE可以运行,但牛客网EOF错误……'''
##用sys……
import sys
IDs=[]
while 1:
    Id=sys.stdin.readline()
    if Id.strip()=='':
        break
    IDs.append(Id.strip())
    
for i in IDs:
	i=i.replace(' ','')
	if len(i)<=6:
		print(i)
	elif len(i)<14:
		print(i[:6]+' '+i[6:])
	else:print(i[:6]+' '+i[6:14]+' '+i[14:])
'''通过'''

你可能感兴趣的:(互联网编程题们)