测试二

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

posted @ 2020-11-30 20:08  Allin007  阅读(164)  评论(0)    收藏  举报