【作业】2022.4.21 字符串作业

  1. 输入一个字符串,打印所有奇数位上的字符(下标是1,3,5,7…位上的字符)

    例如: 输入’abcd1234 ’ 输出’bd24’

# 这是一个打印字符串中奇数位字符的程序

str1 = 'abcd1234'
print(str1[1::2])
  1. 输入用户名,判断用户名是否合法(用户名长度6~10位)
# 这是一个判断用户名是否合法的程序

name = input('请输入用户名:')
n = len(name)
while n < 6 or n > 10:
    name = input('不合法,请重新输入用户名:')
    n = len(name)
print('合法')
  1. 输入用户名,判断用户名是否合法(用户名中只能由数字和字母组成)

    例如: ‘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('合法')
  1. 输入用户名,判断用户名是否合法(用户名必须包含且只能包含数字和字母,并且第一个字符必须是大写字母)

    例如: ‘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('不合法')
  1. 输入一个字符串,将字符串中所有的数字字符取出来产生一个新的字符串

    例如:输入**‘abc1shj23kls99+2kkk’** 输出:‘123992’

# 这是一个提取字符串中数字字符的程序

str_6 = 'abc1shj23kls99+2kkk'
str_num = ''
for x in str_6:
    if '0' <= x <= '9':
        str_num += x
print('数字字符有:', str_num)
  1. 输入一个字符串,将字符串中所有的小写字母变成对应的大写字母输出 (用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)
  1. 输入一个小于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))
  1. 输入一个字符串,统计字符串中非数字字母的字符的个数

    例如: 输入**‘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)
  1. 输入字符串,将字符串的开头和结尾变成’+',产生一个新的字符串

    例如: 输入字符串**‘abc123’, 输出’+bc12+'**

# 这是一个把字符串首尾变成'+'的程序

str_9 = input('请输入一段字符串:')
print('+' + str_9[1:-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])
  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. 获取两个字符串中公共的字符

    例如: 字符串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
  • 13
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Sprite.Nym

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值