Python第014讲课后测试题:各种奇葩的内置方法(字符串)

各种奇葩的内置方法

测试题:

0. 还记得如何定义一个跨越对行的字符串吗(请至少写出两种实现的方法)?

方法一:

>>> str1 = '''床前明月光,疑似地上霜。
举头望明月,低头思故乡。'''

方法二:

>>> str2 = ('床前明月光,疑似地上霜。'
'举头望明月,低头思故乡。')

方法三:

>>> str3 = '床前明月光,疑似地上霜。\
举头望明月,低头思故乡。'

1. 三引号字符串通常我们用于做什么使用?

三引号字符串不赋值的情况下,通常当作跨行注释使用,例如:

	'''这是一个三引号字符串用于注释的例子
	例子虽然只是简简单单的一句话,
	却毫无遮掩地体现了作者用情至深,
	所谓爱至深处情至简!'''

2. file1 = open('C:\windows\temp\qq.txt', 'r')表示以只读方法打开"C:\windows\temp\qq.txt"这个文本文件,但事实上这个语句会报错!知道为什么吗?你会如何修改?

会报错是因为在字符串中,我们约定“\t”“\r” 分别表示 “横向制表符(TAB)”“回车符”
因此并不会按照我们计划的路径去打开文件。
Python 为我们铺好了解决的道路,只需要使用原始字符串操作符(R或r)即可:

>>> file1 = open(r'C:\windows\temp\qq.txt', 'r')

3. 有字符串:str1 = '<a href=“http://www.fishc.com/dvd” target="_blank">鱼C资源打包',请问如何取出子字符串:'www.fishc.com'

>>> str1[16:29]
'www.fishc.com'

4. 如果使用负数作为索引值进行分片操作,按照第三题的要求你能够正确目测出结果吗?

>>> str1[-41:-28]
'www.fishc.com'

5. 还是第三题那个字符串,请问下边语句会显示什么内容?

>>> str1[20:-32]
'fishc'

‘fishc’,加入了负数索引,问题变得有些复杂,不过自己多尝试几次就可以熟练掌握了

6. 根据只有智商高于 150 的鱼友才能解开这个字符串(还原为有意义的字符串):
str1 = 'i2sl540vvvb4e3bferi32s56h;$c43.sfc67o0cm99'

>>> str1[::3]
'i10vefishc.com'

动动手:

0. 请写一个密码安全性检查的代码:check.py

'''
	密码安全性检查代码

	低级密码要求:
		1. 密码由单纯的数字或字母组成
		2. 密码长度小于等于 8 位

	中级密码要求:
		1. 密码必须由数字、字母或特殊字符(仅限:~!@#$%^&*()_=-+/,.?<>;:[]{}|\)任意两种组合
		2. 密码长度不能低于 8 位

	高级密码要求:
		1. 密码必须由数字、字母或特殊字符(仅限:~!@#$%^&*()_=-+/,.?<>;:[]{}|\)三种组合
		2. 密码只能由字母开头
		3. 密码长度不能低于 16 位
	'''
# 数字
nums = '0123456789'
# 26字母
letter = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
# 特殊字符
combination = r''' ~!@#$%^&*()_-+=/,.?<>;:[]{}|\ '''

# 用户输入密码
password = input('请输入需要检查的密码组合: ')

# 取出用户输入的密码长度
lenght = len(password)
# while循环,判断用户输入的有空格或密码长度为空时,则需要用户重新输入密码
while (password.isspace() or lenght == 0):
    password = input('您输入的密码有空格(或为空),请重新输入:')
    # 取出用户输入的密码的长度
    lenght = len(password)
# 判断用户输入的密码长度是否小于等于 8 位
if lenght <= 8:
    # 是,属于低级密码
    flag_len = 1
elif 8 < lenght < 16:   # 判断密码长度是否大于 8 位,小于 16 位
    # 是,属于中级密码
    flag_len = 2
else:
    # 否则,属于高级密码
    flag_len = 3
# 定义变量,赋初始值为0
flag_con = 0

# 判断是否包含特殊字符
for each in password:
    if each in combination:
        flag_con += 1
        break
    
# 判断是否包含字母
for each in password:
    if each in letter:
        flag_con += 1
        break

# 判断是否包含数字
for each in password:
    if each in nums:
        flag_con += 1
        break

# while循环,打印结果
while 1:
    print('您的密码安全级别评定为: ', end = '')    # 打印提示,末尾不换行,加空格
    # 判断用户输入的密码的长度是否符合低级 或 判断密码中包含的字母是否符合低级
    if flag_len == 1 or flag_con == 1:
        print('低级')     # 符合
    # 判断用户输入的密码的长度 和 包含的特殊字符 和 包含的字母 是否符合高级
    elif flag_len == 3 and flag_con == 3 and (password[0] in letter):
        print('高级')     # 符合
        print('请继续保持!')
        break   # 跳出循环
    else:   # 否则,符合中级密码
        print('中级')
    # 打印提示
    print('请按以下方式提升您的密码安全级别:\n\
    \t1. 密码必须由数字、字母或特殊字符三种组合\n\
    \t2. 密码只能由字母开头\n\
    \t3. 密码长度不能低于16位')
    break   # 跳出循环

哈哈,这最后一题招来不少“民愤”,自己挖了个坑…
这里把相关的疑问给大家解释下:

(1) 为啥要用 while 1 呢?主要是为了实现 “如果结果是低或中则打印如何提升密码安全级别的提示,而高则直接退出”
(2) 为啥把 “高” 放中间呢?因为其判断最为麻烦(注意还要求必须是字母开头),所以很有可能满足了 “中” 却因为额外的条件满足不了 “高”

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值