第014讲:字符串:各种奇葩的内置方法 | 学习记录(小甲鱼零基础入门学习Python)

(标答出处: 鱼C论坛)
《零基础入门学习Python》

测试题:

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

    例一:str = (‘春眠不觉晓,
    处处闻啼鸟。
    也来风雨声,
    花落知多少。’)
    例二:str = ‘春眠不觉晓,
    处处闻啼鸟。
    也来风雨声,
    花落知多少。’
    例三:str = “”“春眠不觉晓,
    处处闻啼鸟。
    也来风雨声,
    花落知多少。”""

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

    三引号字符串通常用与注释功能

  3. file1 = open(‘C:\windows\temp\readme.txt’, ‘r’) 表示以只读方式打开“C:\windows\temp\readme.txt”这个文本文件,但事实上这个语句会报错,知道为什么吗?你会如何修改?

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

  4. 有字符串:str1 = ‘鱼C资源打包’,请问如何提取出子字符串:‘www.fishc.com

    str1[16:29]

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

    str1[-45:-32]

  6. 还是第三题那个字符串,请问下边语句会显示什么内容?
    str1[20:-36]

    fishc

  7. 据说只有智商高于150的鱼油才能解开这个字符串(还原为有意义的字符串):str1 = ‘i2sl54ovvvb4e3bferi32s56h;$c43.sfc67o0cm99’

    >>> str1 = 'i2sl54ovvvb4e3bferi32s56h;$c43.sfc67o0cm99'
    >>> str1 = str1[0]+' '+str1[3]+str1[6:8]+str1[12]+str1[15]+' '+str1[18]+str1[21]+str1[24]+str1[-12]+str1[-9]+str1[-6]+str1[-3]
    >>> str1
    'i lovef ish.com'
    

动动手:

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

    密码安全性检查代码

    低级密码要求:

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

    中级密码要求:

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

    高级密码要求:

    1. 密码必须由数字、字母及特殊字符(仅限:~!@#$%^&*()_=-/,.?<>;:[]{}|\)三种组合
    2. 密码只能由字母开头
    3. 密码长度不能低于16位
    mima = input ('请输入你的密码:')
    diyi =  mima[0]
    teshuzifu = ('~!@#$%^&*()_=-/,.?<>;:[]{}|\\')
    counta = 0
    countb = 0
    countc = 0
    
    for i in mima:
        if i in teshuzifu:
            counta += 1
        if i.isdigit():
            countb += 1
        if i.isalpha():
            countc += 1
    
    count = counta + countb +countc
    
    
    if ( 0 < count <= 8 and (countb * countc == 0) and counta == 0):
            print ('安全性:低级')
    else:
        if(  count<16 ):
            if (countb * countc * counta == 0) and ( counta==0 or countb ==0 or countc ==0 ):
                print ('安全性:中级')
        else:
            if( count>=16 ):
                if ( countb * countc * counta > 0 and ( diyi.isalpha()==True ) ):
                     print('安全性:高级')
      
    

标答:

测试题答案:

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

方法一:

str1 = ‘’‘待我长发及腰,将军归来可好?
此身君子意逍遥,怎料山河萧萧。
天光乍破遇,暮雪白头老。
寒剑默听奔雷,长枪独守空壕。
醉卧沙场君莫笑,一夜吹彻画角。
江南晚来客,红绳结发梢。’’’

方法二:

str2 = ‘待卿长发及腰,我必凯旋回朝。
昔日纵马任逍遥,俱是少年英豪。
东都霞色好,西湖烟波渺。
执枪血战八方,誓守山河多娇。
应有得胜归来日,与卿共度良宵。
盼携手终老,愿与子同袍。’

方法三:

str3 = (‘待卿长发及腰,我必凯旋回朝。’
‘昔日纵马任逍遥,俱是少年英豪。’
‘东都霞色好,西湖烟波渺。’
‘执枪血战八方,誓守山河多娇。’
‘应有得胜归来日,与卿共度良宵。’
‘盼携手终老,愿与子同袍。’)

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

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

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

    会报错是因为在字符串中,我们约定“\t”和“\r”分别表示“横向制表符(TAB)”和“回车符”(详见: http://bbs.fishc.com/thread-39140-1-1.html),因此并不会按照我们计划的路径去打开文件。

    Python 为我们铺好了解决的道路,只需要使用原始字符串操作符(R或r)即可:

    >>> file1 = open(r'C:\windows\temp\readme.txt', 'r')
    
  3. 有字符串:str1 = ‘<a href=“http://www.fishc.com/dvd” target="_blank">鱼C资源打包’,请问如何提取出子字符串:‘www.fishc.com

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

    >>> str1[-45:-32]
    
  5. 还是第三题那个字符串,请问下边语句会显示什么内容?

    >>> str1[20:-36]
    

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

  6. 据说只有智商高于150的鱼油才能解开这个字符串(还原为有意义的字符串):str1 = ‘i2sl54ovvvb4e3bferi32s56h;$c43.sfc67o0cm99’
    >>> str1[::3]

动动手答案:

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

低级密码要求:

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

中级密码要求:

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

高级密码要求:

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

passwd = input('请输入需要检查的密码组合:')

# 判断长度
length = len(passwd)
	
while (passwd.isspace() or length == 0) :
passwd = input("您输入的密码为空(或空格),请重新输入:")

if length <= 8:
	 flag_len = 1
elif 8 < length < 16:
	flag_len = 2
else:
	flag_len = 3
	flag_con = 0

# 判断是否包含特殊字符
for each in passwd:
	if each in symbols:
		flag_con += 1
	        break
    
# 判断是否包含字母
for each in passwd:
	if each in chars:
		flag_con += 1
		break
	
# 判断是否包含数字
for each in passwd:
	if each in nums:
		flag_con += 1
		break    

# 打印结果
while 1 :
	print("您的密码安全级别评定为:", end='')
	if flag_len == 1 or flag_con == 1 :
		print("低")
	elif flag_len == 2 or flag_con == 2 :
		print("中")
	else :
		print("高")
		print("请继续保持")
		break
	print("请按以下方式提升您的密码安全级别:\n\
	\t1. 密码必须由数字、字母及特殊字符三种组合\n\
	 \t2. 密码只能由字母开头\n\
	\t3. 密码长度不能低于16位'")
	 break



猜你喜欢

转载自blog.csdn.net/qq_38970783/article/details/84424197