zoukankan      html  css  js  c++  java
  • 测试二

    15. 用正则过滤掉英文和数字

      题目:字符串a = "not 404 found 张三 99 深圳",每个词中间是空格
      输出:"张三 深圳"
    
    import re
    
    a = "not 404 found 张三 99 深圳"
    list = a.split(" ")
    print(list)  # ['not', '404', 'found', '张三', '99', '深圳']
    res = re.findall('d+|[a-zA-Z]+', a)
    for i in res:
        list.remove(i)
    new_str = " ".join(list)
    print(res)  # ['not', '404', 'found', '99']
    print(new_str)  # 张三 深圳
    
    p:匹配小数
    import re
    
    a = "not 404 50.56 found 张三 99 深圳"
    list = a.split(" ")
    print(list)  # ['not', '404', '50.56', 'found', '张三', '99', '深圳']
    res = re.findall('d+.?d*|[a-zA-Z]+', a)
    for i in res:
        list.remove(i)
    new_str = " ".join(list)
    print(res)  # ['not', '404', '50.56', 'found', '99']
    print(new_str)  # 张三 深圳
    

    16. filter方法求出列表所有奇数并构造新列表

    a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    filter() 函数用于过滤序列,过滤掉不符合条件的元素,
    返回由符合条件元素组成的新列表。该接收两个参数,第一个为函数,
    第二个为序列,序列的每个元素作为参数传递给函数进行判断,然后返回 True 或 False,
    最后将返回 True 的元素放到新列表

    a = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    
    
    def fn(a):
        return a % 2 == 1
    newlist =  filter(fn, a)
    newlist = [i for i in newlist]
    print(newlist)  # [1, 3, 5, 7, 9]
    

    使用列表推导式:

    res = [i for i in a if i%2==1]
    print(res)  # [1, 3, 5, 7, 9]
    

    re.complie是将正则表达式编译成一个对象,加快速速,并重复使用

    import re
    
    
    a = "not 404 found 张三 99 深圳"
    list = a.split(" ")
    print(list)
    exp = re.compile('d+|[a-zA-Z]+')
    res = exp.findall(a)
    for i in res:
        list.remove(i)
    new_str = " ".join(list)
    print(res)
    print(new_str)
    

    17. 合并列表

    extend可以将另一个集合中的元素逐一添加到列表中,区别去append整体添加

    list1 = [1, 5, 7, 9]
    list2 = [2, 2, 6, 8]
    list1.extend(list2)
    print(list1)  # [1, 5, 7, 9, 2, 2, 6, 8]
    list1.sort(reverse = False)
    print(list1)  # [1, 2, 2, 5, 6, 7, 8, 9]
    

    18. 用python删除文件和用linux命令删除文件方法

    Python: os.remove(文件名)
    Linux: rm 文件名

    19. 用时间戳记录error和warning等发生时间

    题目:log日志中,我们需要用时间戳记录error,warning等的发生时间,请用datetime模块打印当前时间戳

    import datetime
    a = str(datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')) + ' 星期: ' + str(datetime.datetime.now().isoweekday())
    print(a)  # 当前时间
    

    20. 数据库优化查询方法

    21. 写一段自定义异常代码

    自定义异常常用raise抛出异常

    def fn():
          try:
                for i in range(5):
                      if i > 2:
                            raise Exception("数字大于2了")
          except Exception as ret:
                print(ret)
    
    fn()
    

    22. 将[[1, 2], [3, 4], [5, 6]]展开

    a = [[1, 2], [3, 4], [5, 6]]
    x = [j for i in a for j in i]
    print(x)
    # 将列表转成numpy矩阵,通过numpy的flatten()方法,
    import numpy as np
    b = np.array(a).flatten().tolist()
    print(b)
    

    23. x="abc",y="def",z=["d","e","f"],分别求出x.join(y)和x.join(z)返回的结果

    join()括号里面的是可迭代对象,x插入可迭代对象中间,形成字符串,结果一样

    x = "abc"
    y = "def"
    z = ["d", "e", "f"]
    
    m = x.join(y)
    n = x.join(z)
    print(m)  # dabceabcf
    print(n)  # dabceabcf
    

    24. 举例说明异常模块中try execpt else finally的相关意义

    try:
        num = 100
        print(num)
    except NameError as errorMsg:
        print('产生错误了:%s' % errorMsg)
    else:
        print('没有捕获到异常,则执行该语句')
    
    
    try:
        num = 100
        print(num)
    except NameError as errorMsg:
        print('产生错误了:%s' % errorMsg)
    finally:
        print('不管是否捕获到异常,都执行该句')
    '''
    100
    没有捕获到异常,则执行该语句
    100
    不管是否捕获到异常,都执行该句
    '''
    

    25. 举例说明zip()函数用法

    zip()函数在运算时,会以一个或多个序列(可迭代对象)做为参数,返回一个元组的列表。同时将这些序列中并排的元素配对。
    zip()参数可以接受任何类型的序列,同时也可以有两个以上的参数;当传入参数的长度不同时,zip能自动以最短序列长度为准进行截取,获得元组。

    a = [1, 2]
    b = [3, 4]
    res = [i for i in zip(a, b)]
    print(res)
    
    a = (1, 2)
    b = (3, 4)
    res = [i for i in zip(a, b)]
    print(res)
    
    a = "ab"
    b = "xyz"
    res = [i for i in zip(a, b)]
    print(res)
    
    A = zip(("a", "b", "c", "d", "e",), (1, 2, 3, 4, 5))
    A0 = dict(A)
    print(A0)
    '''
    [(1, 3), (2, 4)]
    [(1, 3), (2, 4)]
    [('a', 'x'), ('b', 'y')]
    {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}
    '''
    

    26. 提高Python运行效率的方法

    1、使用生成器,因为可以节约大量内存
    2、循环代码优化,避免过多重复代码的执行
    3、核心模块用Cython PyPy等,提高效率
    4、多进程、多线程、协程
    5、多个if elif条件判断,可以把最有可能先发生的条件放到前面写,这样可以减少程序判断的次数,提高效率

    27. 简述mysql和redis区别

    redis:内存型非关系数据库,数据保存在内存中,速度快
    mysql:关系型数据库,数据保存在磁盘中,检索的话,会有一定的IO操作,访问速度相对慢

    28. 求三个方法打印结果

    fn("one",1)直接将键值对传给字典;
    fn("two",2)因为字典在内存中是可变数据类型,所以指向同一个地址,传了新的额参数后,会相当于给字典增加键值对
    fn("three",3,{})因为传了一个新字典,所以不再是原先默认参数的字典

    def fn(k, v, dic={}):
        dic[k] = v
        print(dic)
    
    
    fn("one", 1)
    fn("two", 2)
    fn("three", 3, {})
    '''
    {'one': 1}
    {'one': 1, 'two': 2}
    {'three': 3}
    '''
    

    参考:https://www.cnblogs.com/finer/p/12846475.html

    Live what we love, do what we do, follow the heart, and do not hesitate.
  • 相关阅读:
    day01-java开发前奏
    ASP.NET MVC RDLC-导出
    SAS学习目标层次
    Chapter003[SAS DATA步之全解密-02]
    Chapter002[SAS DATA步之全解密-01]
    Chapter001[SAS LICENCE 获取方法]
    VB.NET中如何在字符串中使用双引号
    ASP.NET数据处理进度条
    GridView内容详解(转载)
    js正则表达式限制文本框只能输入数字,小数点,英文字母,汉字等各类代码
  • 原文地址:https://www.cnblogs.com/failan/p/14051760.html
Copyright © 2011-2022 走看看