实现一个函数来来对目标字符串进行校验,使其满足以下全部条件

本文介绍了一个用于校验字符串是否满足特定条件的函数实现,包括长度、包含大小写字母及数字等,通过正则表达式和单元测试确保了函数的正确性。

实现一个函数来来对目标字符串进行校验,使其满足以下全部条件

  • 不少于6个字符
  • 包含至少一个小写字母
  • 包含至少一个大写字母
  • 包含至少一个数字
  • 只能包含大小写和数字
    示例:
    func(“12ABcd”) -->True
    func(“12ABc”) --> False
    func(“12ABCD”) --> False
    func(“12abcd”) --> False
    func(“ABCdef”) --> False
    func(“12AB cd”) --> False
import re
import unittest
def func(str_check):
    len_flag = False if len(str_check) < 6 else True
    char_up = False if re.search('[A-Z]', str_check) == None else True
    char_down = False if re.search('[a-z]', str_check) == None else True
    digital = False if re.search('[0-9]', str_check) == None else True
    flag = True if re.search('[^A-Za-z0-9]', str_check) == None else False
    return len_flag and char_up and char_down and digital and flag

class DefaultTestCase(unittest.TestCase):
    def test_func(self):
        self.assertEqual(func('12ABcd'), True)
        self.assertEqual(func('12ABc'), False)
        self.assertEqual(func('12ABCD'), False)
        self.assertEqual(func('12abcd'), False)
        self.assertEqual(func('ABCdef'), False)
        self.assertEqual(func('12AB cd'), False)

if __name__ == '__main__':
    unittest.main()

执行结果

Testing started at 21:05 ...
ssh://wfq@192.168.174.132:22/home/wfq/python27/bin/python -u /home/wfq/.pycharm_helpers/pycharm/_jb_unittest_runner.py --path /home/wfq/ops/test/check_str_re.py
Launching unittests with arguments python -m unittest discover -s /home/wfq/ops/test -p check_str_re.py -t /home/wfq/ops/test in /home/wfq/ops/test


Ran 1 test in 0.005s

OK
Process finished with exit code 0

点击下载

实现一个既能检查字符串是否为回文又能验证括号匹配的函数,通常需要两个步骤: 1. **判断回文**:首先检查输入字符串是否可以反转后与原字符串相等。一种常见做法是对字符串进行两头扫描,一边从前往后读取字符(left),另一边从后往前读取(right)。如果发现左指针位置的字符不等于右指针位置的字符,并且它们都不为空,说明不是回文。当左右指针相遇或者越过时,说明是回文。 2. **验证括号匹配**:对于括号配对,可以利用栈数据结构。遍历输入字符串,对于每一对括号(如 '(', ')'),将左括号压入栈,遇到右括号时,检查栈顶元素是否与其对应。如果为空或者不匹配,说明括号不匹配。遍历结束后,如果栈为空,表示所有括号都已正确关闭。 下面是一个Python示例函数: ```python def is_palindrome_and_brackets(s): def check_palindrome(): left, right = 0, len(s) - 1 while left < right: if s[left] != s[right]: return False left += 1 right -= 1 return True def check_brackets(): bracket_stack = [] for char in s: if char in "([{": bracket_stack.append(char) elif char in ")]}": if not bracket_stack or (char != bracket_stack.pop() and char != "\\" + bracket_stack[-1]): return False return not bracket_stack return check_palindrome() and check_brackets() # 示例 print(is_palindrome_and_brackets("madam")) # 输出:True print(is_palindrome_and_brackets("())")) # 输出:False ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值