-
输入一个字符串,打印所有奇数位上的字符(下标是1,3,5,7…位上的字符)
例如: 输入’abcd1234 ’ 输出’bd24’
# 这是一个打印字符串中奇数位字符的程序
str1 = 'abcd1234'
print(str1[1::2])
- 输入用户名,判断用户名是否合法(用户名长度6~10位)
# 这是一个判断用户名是否合法的程序
name = input('请输入用户名:')
n = len(name)
while n < 6 or n > 10:
name = input('不合法,请重新输入用户名:')
n = len(name)
print('合法')
-
输入用户名,判断用户名是否合法(用户名中只能由数字和字母组成)
例如: ‘abc’ — 合法 ‘123’ — 合法 ‘abc123a’ — 合法
# 这是一个判断用户名是否合法的程序
# 只判断是否合法版本:
name = input('请输入用户名:')
for x in name:
if not('0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z'):
print('不合法')
break
else:
print('合法')
# 不合法就循环版本:
name = input('请输入用户名:')
count_name = 0
for x in name:
if not ('0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z'):
count_name += 1
while count_name:
name = input('不合法,请重新输入用户名:')
count_name = 0
for x in name:
if not ('0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z'):
count_name += 1
print('合法')
-
输入用户名,判断用户名是否合法(用户名必须包含且只能包含数字和字母,并且第一个字符必须是大写字母)
例如: ‘abc’ — 不合法 ‘Mabc’ — 不合法 ‘123’ — 不合法 ‘abc123’ — 不合法 ‘Abc123ahs’ — 合法
# 这是一个判断用户名是否合法的程序
# 录入信息
name = input('请输入用户名:')
# 如果第一个字符是大写字符就继续看后面,否则直接不合法
if 'A' <= name[0] <= 'Z':
# 统计数字个数
count_num = 0
# 遍历name,遇到数字就给个数+1
# 因为第一个字符已经是字母了,所以后面不用再管字母
# 遇到其他的字符直接break
for x in name[1:]:
if '0' <= x <= '9':
count_num += 1
elif 'a' <= x <= 'z' or 'A' <= x <= 'Z':
pass
else:
print('不合法')
break
else:
# 如果数字个数>0,合法,如果=0,不合法
if count_num:
print('合法')
else:
print('不合法')
else:
print('不合法')
-
输入一个字符串,将字符串中所有的数字字符取出来产生一个新的字符串
例如:输入**‘abc1shj23kls99+2kkk’** 输出:‘123992’
# 这是一个提取字符串中数字字符的程序
str_6 = 'abc1shj23kls99+2kkk'
str_num = ''
for x in str_6:
if '0' <= x <= '9':
str_num += x
print('数字字符有:', str_num)
-
输入一个字符串,将字符串中所有的小写字母变成对应的大写字母输出 (用upper方法和自己写算法两种方式实现)
例如: 输入**‘a2h2klm12+’ ** 输出 ‘A2H2KLM12+’
# 这是一个将字符串中小写字母变成大写字母的程序
# 方法1
str_7 = 'a2h2klm12+'
print(str_7.upper())
# 方法2
str_upper = ''
for x in str_7:
if 'a' <= x <= 'z':
# 同增同减差不变,大小写字母编码值差值都是32
str_upper += chr(ord(x) - 32)
else:
str_upper += x
print(str_upper)
-
输入一个小于1000的数字,产生对应的学号
例如: 输入**‘23’,输出’py1901023’** 输入**‘9’, 输出’py1901009’** 输入**‘123’,输出’py1901123’**
# 这是一个输入数字产生学号的程序
# 方法1:通过给输入号码+1000的方式补0
str_pre = 'py190'
str_num = 1000
while str_num >= 1000:
str_num = int(input('请输入一个小于1000的数:'))
print(str_pre + str(str_num + 1000))
# 方法2:通过加'0'的方式补0
str_pre = 'py1901'
n = 4
while n >= 4:
str_num = input('请输入一个小于1000的数:')
n = len(str_num)
print(str_pre + (3 - n) * '0' + str_num)
# 方法3:通过zfill补0
str_pre = 'py1901'
n = 4
while n >= 4:
str_num = input('请输入一个小于1000的数:')
n = len(str_num)
print(str_pre + str_num.zfill(3))
#-----------------------------------------------------------------------
# 上面的方法虽然好,但是万一有人不输入数字,而输入“炒饭”两个字,就出大问题了
# 对于方法1会报错,对于方法2和3学号则会变成“py19010炒饭”
# 所以有了超级无敌炫酷的Ultra进化版方法4(在方法1的基础上升级)
str_pre = 'py190'
str_num = 1000
while str_num >= 1000:
str_num = input('请输入一个小于1000的数:')
# 这一步是为了防止有的人才输都不输直接回车导致程序报错
if str_num:
# 遍历输入的字符串,如果遇到不是数字的,就输出警告
for x in str_num:
if not '0' <= x <= '9':
print('请不要玩弄程序员的感情!!')
str_num = 1000
break
else:
str_num = int(str_num)
else:
print('请不要玩弄程序员的感情!!')
str_num = 1000
print(str_pre + str(str_num + 1000))
-
输入一个字符串,统计字符串中非数字字母的字符的个数
例如: 输入**‘anc2+93-sj胡说’** 输出:4 输入**‘===’** 输出:3
# 这是一个统计字符串中非数字字母字符的程序
str_9 = input('请输入一段字符串:')
count_9 = 0
for x in str_9:
if not ('0' <= x <= '9' or 'a' <= x <= 'z' or 'A' <= x <= 'Z'):
count_9 += 1
print('非字母数字字母字符个数是:', count_9)
-
输入字符串,将字符串的开头和结尾变成’+',产生一个新的字符串
例如: 输入字符串**‘abc123’, 输出’+bc12+'**
# 这是一个把字符串首尾变成'+'的程序
str_9 = input('请输入一段字符串:')
print('+' + str_9[1:-1] + '+')
-
输入字符串,获取字符串的中间字符
例如: 输入**‘abc1234’** 输出:‘1’ 输入**‘abc123’** 输出**‘c1’**
# 这是一个获取字符串中间字符的程序
str_11 = input('请输入字符串:')
n = len(str_11)
x = n // 2
if n % 2:
print(str_11[x])
else:
print(str_11[x - 1:x + 1])
-
写程序实现字符串函数find/index的功能(获取字符串1中字符串2第一次出现的位置)
例如: 字符串1为:how are you? Im fine, Thank you! , 字符串2为:you, 打印8
# 这是一个实现find/index功能的程序
# 方法1:每次都要切片
# 录入信息
str_12_1 = 'how are you? Im fine, Thank you!'
str_12_2 = 'you'
# 得到两个字符串长度
n1 = len(str_12_1)
n2 = len(str_12_2)
# 依次得到字符串1中各个字符的下标
for index_1 in range(n1 - n2 + 1):
# 如果字符串2与字符串1的切片相等,就输出下标并break
if str_12_2 == str_12_1[index_1:index_1 + n2]:
print(index_1)
break
# 如果循环完了都没找到相等的就输出'找不到'
else:
print('找不到')
# 方法2:先匹配到首字母相同的位置再去切片
str_12_1 = 'how are you? Im fine, Thank you!'
str_12_2 = 'you'
n1 = len(str_12_1)
n2 = len(str_12_2)
for index1, item1 in enumerate(str_12_1[:1 - n2]):
if item1 == str_12_2[0]:
if str_12_1[index1:index1 + n2] == str_12_2:
print(index1)
break
else:
print('找不到')
-
获取两个字符串中公共的字符
例如: 字符串1为:abc123, 字符串2为: huak3 , 打印:公共字符有:a3
# 这是一个获取两个字符串中公共字符的程序
str_13_1 = '1y953tgfoabf9037643Q8UREJOBKF9QTUY903HEIOB'
str_13_2 = 'Nfohsz974egsduf90auqAIUFUI'
str_13_3 = ''
# 由于不管遍历哪个字符串,最终执行循环体次数都是两字符串长度之积,所以不用特意遍历短的字符串
for x in str_13_1:
if x not in str_13_3:
if x in str_13_2:
str_13_3 += x
print('公共字符有:', str_13_3)
# 9gfoa074UFI