1.列表和元组之间的区别是?
列表和元组都是python内置的集合类型,列表用list表示,元组用tuple表示
list是有序的动态数组,引用不可变但是可以改变元素的个数,列表元素下标从0开始,列表用[ ] 表示,列表相关操作的方法有append(),len(),extend(+),insert(index, object)等等。
元组与列表类似,但是元组的元素不能修改,用()表示,Python在显示只有1个元素的tuple时,会加一个逗号,以免引起歧义,例如 t (1,) 。
2.解释一下Python中的继承
python支持多继承,一个类可以继承多个父类,父类中非私有的属性和方法都会被继承,如果多个父类中有同名方法,在子类调用个方法的时候,调用的是父类类名列表中第一个父类的方法。
子类可以调用mro()查看子类对象查找类的先后顺序。
3.Python中的字典是什么?
dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。字典中的key唯一,value可以重复可以为空。set集合相当于没有值的dict
dict是一个可变类型
- 字典和列表一样,能够存储多个数据
- 列表中找某个元素时,根据下标进行的
- 字典中找某个元素时,根据’名字’(就是冒号:前面的那个值,例如上面代码中的’name’、‘id’、‘sex’)
- 字典的每个元素由2部分组成,键:值。例如 ‘name’:‘班长’ ,'name’为键,'班长’为值
若访问不存在的键,则会报错,如果不确定字典中是否存在某个键而又想获取其值,可以使用get方法,还可以设置默认值:
age = info.get(‘age’, q) # 若info中不存在’age’这个键,就返回默认值18
4.请解释使用*args和kwargs的含义
- 加*的args存放所有未命名的变量参数,args是元组;
- 加**的变量kwargs存放命名参数,如key=value的参数, kwargs为字典。
- *args:表示一组值的集合,普通数据
- **kwargs:表示k-v格式的数据
5.请写一个Python逻辑,计算一个文件中的大写字母数量
w = open("test.txt",'r',True)
sum = 0
while True:
ff = w.read(1)
if not ff:
break
if ff.isupper():
sum+=1
print("大写字母个数:%d"%sum)
w.close()
6.什么是负索引?
Python中的序列索引可以是正也可以是负。如果是正索引,0是序列中的第一个索引,1是第二个索引。如果是负索引,(-1)是最后一个索引而(-2)是倒数第二个索引。
7.Python区分大小写吗?
python严格区分大小写, Ange != ange
8.怎么移除一个字符串中的前导空格?
使用lstrip()删除字符串中的前导空格
9.怎样将字符串转换为小写?
lower() 大写转小写
upper() 小写转大写
10 .Python中的pass语句是什么?
pass 是空语句,不做任何事情,用做占位语句。为了保持程序结构的完整性。
如果定义一个空函数会报错,但是是可以用 pass 填充,使程序可以正常运行。
11.解释一下Python中的//,%和 ** 运算符
运算符 |
描述 | 实例 |
---|---|---|
// | 取整除 | 返回商的整数部分, 9//2 输出结果 4 , 9.0//2.0 输出结果 4.0 |
% | 取余(取模) | 返回除法的余数 |
** | 幂 | 返回x的y次幂 |
12.在Python中有多少种运算符?解释一下算数运算符。
python中主要有7种运算符:算术运算符,赋值运算符,关系运算符,逻辑运算符,位运算符,成员运算符,身份运算符等等
运算符 |
描述 | 实例 |
---|---|---|
+ | 加 | 1+2=3 |
- | 减 | 3-1=2 |
* | 乘 | 3*2=6 |
/ | 除 | 6/3=2 |
// | 取整除 | 9.0//2.0=4.0 |
% | 取余 | 9.0%2.0=1.0 |
** | 幂 | 返回x的y次幂,2**3=8 |
身份运算符
运算符 |
描述 | 实例 |
---|---|---|
is | is 是判断两个标识符是不是引用自一个对象 | x is y, 类似 id(x) == id(y) , 如果引用的是同一个对象则返回 True,否则返回 False |
is not | is not 是判断两个标识符是不是引用自不同对象 | x is not y , 类似 id(a) != id(b)。如果引用的不是同一个对象则返回结果 True,否则返回 False。 |
13.解释一下Python中的关系运算符
运算符 |
描述 | 示例 |
---|---|---|
== | 检查两个操作数的值是否相等,如果是则条件变为真。 | 如a=3,b=3则(a == b) 为 true. |
!= | 检查两个操作数的值是否相等,如果值不相等,则条件变为真。 | 如a=1,b=3则(a != b) 为 true. |
<> | 检查两个操作数的值是否相等,如果值不相等,则条件变为真。 | 如a=1,b=3则(a <> b) 为 true。这个类似于 != 运算符 |
> | 检查左操作数的值是否大于右操作数的值,如果是,则条件成立。 | 如a=7,b=3则(a > b) 为 true. |
< | 检查左操作数的值是否小于右操作数的值,如果是,则条件成立。 | 如a=7,b=3则(a < b) 为 false. |
>= | 检查左操作数的值是否大于或等于右操作数的值,如果是,则条件成立。 | 如a=3,b=3则(a >= b) 为 true. |
<= | 检查左操作数的值是否小于或等于右操作数的值,如果是,则条件成立。 | 如a=3,b=3则(a <= b) 为 true. |
14.解释一下Python中的赋值运算符
运算符 | 描述 | 实例 |
---|---|---|
+= | 加法赋值运算符 | c += a 等效于 c = c + a |
-= | 减法赋值运算符 | c -= a 等效于 c = c - a |
*= | 乘法赋值运算符 | c *= a 等效于 c = c * a |
/= | 除法赋值运算符 | c /= a 等效于 c = c / a |
%= | 取模赋值运算符 | c %= a 等效于 c = c % a |
**= | 幂赋值运算符 | c = a 等效于 c = c a |
//= | 取整除赋值运算符 | c //= a 等效于 c = c // a |
= | 赋值运算符 | 把=号右边的结果给左边的变量 num=1+2*3 结果num的值为7 |
15.解释一下Python中的逻辑运算符
运算符 |
逻辑表达式 |
描述 | 实例 |
---|---|---|---|
and | x and y | 布尔"与" - 如果 x 为 False,x and y 返回 False,否则它返回 y 的计算值。 | (a and b) 返回 20。 |
or | x or y | 布尔"或" - 如果 x 是 True,它返回 True,否则它返回 y 的计算值。 | (a or b) 返回 10。 |
not | not x | 布尔"非" - 如果 x 为 True,返回 False 。如果 x 为 False,它返回 True。 | not(a and b) 返回 False |
16.解释一下Python中的成员运算符
运算符 | 描述 | 实例 |
---|---|---|
in | 如果在指定的序列中找到值返回 True,否则返回 False。 | x 在 y 序列中 , 如果 x 在 y 序列中返回 True。 |
not in | 如果在指定的序列中没有找到值返回 True,否则返回 False。 | x 不在 y 序列中 , 如果 x 不在 y 序列中返回 True。 |
17 。讲讲Python中的位运算符
运算符
运算符 |
描述 | 实例 |
---|---|---|
& | 按位与运算符:参与运算的两个值,如果两个相应位都为1,则该位的结果为1,否则为0 | (a & b) 输出结果 12 ,二进制解释: 0000 1100 |
| | 按位或运算符:只要对应的二个二进位有一个为1时,结果位就为1。 | (a | b) 输出结果 61 ,二进制解释: 0011 1101 |
^ | 按位异或运算符:当两对应的二进位相异时,结果为1 | (a ^ b) 输出结果 49 ,二进制解释: 0011 0001 |
~ | 按位取反运算符:对数据的每个二进制位取反,即把1变为0,把0变为1 。~x 类似于 -x-1 | (~a ) 输出结果 -61 ,二进制解释: 1100 0011,在一个有符号二进制数的补码形式。 |
<< | 左移动运算符:运算数的各二进位全部左移若干位,由 << 右边的数字指定了移动的位数,高位丢弃,低位补0。 | a << 2 输出结果 240 ,二进制解释: 1111 0000 |
>> | 右移动运算符:把">>"左边的运算数的各二进位全部右移若干位,>> 右边的数字指定了移动的位数 | a >> 2 输出结果 15 ,二进制解释: 0000 1111 |
18.怎样获取字典中所有键的列表?
调用字典的keys(),然后遍历
dict = {"a": 22, "b": 23, "c": 24}
for i in dict.keys():
print(i)
19.怎样声明多个变量并赋值?
#1.
a = b = c = 1
#2.s
a, b = 45, 54
#3.使用元组为多个变量赋值
data = ("zhangsan", "China", "Python")
name, country, language = data
#4.为多个列表同时赋值
list1, list2 = ["hello", "world"], ["word", "count"]
20 .为何不建议以下划线作为标识符的开头
Python 没有私有变量的概念,以下划线__为开头来声明一个私有变量。如果变量非私有,不能使用下划线开头。
21.一行代码实现1到100的求和
print(sum([i for i in range(1, 101)]))
22 .详细描述单例模式的实现
class Singleton(object):
__instance = None
__First_init = True
def __init__(self, name):
if self.__First_init:
self.__First_init = False
self.name = name
print("init")
def __new__(cls, name):
print("new")
# 如果类数字能够__instance没有或者没有赋值
# 那么就创建一个对象,并且赋值为这个对象的引用,保证下次调用这个方法时
# 能够知道之前已经创建过对象了,这样就保证了只有1个对象
if not cls.__instance:
cls.__instance = object.__new__(cls)
return cls.__instance
def run(self):
print("runing")
a = Singleton("zs")
b = Singleton("ls")
print(id(a))
print(id(b))
print(a.name)
print(b.name)
日常使用的电脑上都有一个回收站,在整个操作系统中,回收站只能有一个实例,整个系统都使用这个唯一的实例,而且回收站自行提供自己的实例。因此回收站是单例模式的应用。
确保某一个类只有一个实例,而且自行实例化并向整个系统提供这个实例,这个类称为单例类,单例模式是一种对象创建型模式。
23、详细描述工厂模式的实现
class Person(object):
def __init__(self, name):
self.name = name
def work(self, type):
print(self.name, "开始工作")
axe = Factory.getAxe(type)
axe.cut_tree()
class Axe(object):
def __init__(self, name):
self.name = name
def cut_tree(self):
print("使用", self.name, "砍树")
class StoneAxe(Axe):
def __init__(self):
pass
def cut_tree(self):
print("使用石斧砍树")
class StreeAxe(Axe):
def __init__(self):
pass
def cut_tree(self):
print("使用钢斧砍树")
# 工厂类
class Factory(object):
@staticmethod
def getAxe(type):
if "storn" == type:
return StoneAxe()
elif "stell" == type:
return StreeAxe()
elif "ju" == type:
return ju()
else:
print("参数有误")
class ju(Axe):
def __init__(self):
pass
def cut_tree(self):
print("电锯砍树")
p = Person("zs")
p.work("ju")
Simple Factory模式是Factory Method模式的一种简单的、特殊的实现。也被称为静态工厂模式,通常创建者的创建方法被设计为static方便调用。
1、静态的工厂类
2、用全局函数改写工厂类
24、python操作数据库的步骤
from pymysql import *
conn = connect("192.168.200.24", "root", "123", "mydb", 3306) # 建立连接
cur = conn.cursor()
# 查询
# count = cur.execute("select * from emp") # 执行sql 返回影响的行数
# print(count)
# result = cur.fetchall()
# for i in result:
# print(i)
# 一条查询结果
# result2 = cur.fetchone()
# print(result2)
# 指定个数的查询结果
# result2 = cur.fetchmany(5)
# print(result2)
# 添加
# count = cur.execute("insert into emp(empno,ename) values(1111,'abcd')")
print(count)
conn.commit()# 提交事务
conn.close()
25 、NumPy中几个熟悉的函数的使用
import numpy as np
print(np.abs(-1)) # 绝对值
print(np.sqrt(9)) # 平方根
print(np.square(3)) # 平方np ** 2
print(np.exp(2)) # e^x
print(np.log2(2)) # log2^2 底数为2的对数
print(np.log10(10)) # log10^10 底数为10的对数
print(np.log(np.e)) # loge^e 自然对数
print(np.sign(-165), ":", np.sign(321), ":", np.sign(0)) # 返回各元素的正负号 1正 0零 -1负
print(np.ceil(3.65)) # 大于等于该值的最小整数
print(np.ceil(-3.65))
print(np.floor(3.65)) # 小于等于该值的最小整数
print(np.floor(-3.65))
array = np.random.randint(1, 10, 9).reshape(3, 3)
print(array.sum()) # 所有元素的和 零长度的数组的sum为0
print(array.sum(0)) # 每一列的求和
print(array.sum(1)) # 每一行的求和
list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(np.mean(list)) # 算术平均数 (1+2+3+...+10)/10
# list = []
# print(np.mean(list))# NaN 零长度的数组的mean为NaN
print(np.max(list))
print(np.min(list))
print(np.argmax(list)) # 数组最大值的索引
print(np.argmin(list))
print(np.cumsum(list)) # 所有元素的累计和
print(np.cumprod(list)) # 所有元素的累计积
print("np.modf(100.12) : ", np.modf(100.12)) # 将数组中的小数部分和整数部分以两个独立数组的形式返回
print("np.modf(100.72) : ", np.modf(100.72))
print("np.modf(math.pi) : ", np.modf(np.pi))
list2 = [112, 113.65, 125, 365.56, 788.98]
print("np.modf(list2) : ", np.modf(
list2)) # np.modf(list2) : (array([0. , 0.65, 0. , 0.56, 0.98]), array([112., 113., 125., 365., 788.]))
# subtract:从第一个数组中减去第二个数组中的元素
list3 = [3, 4, 5]
list4 = [1, 1, 1]
print(np.subtract(list3, list4))
# add:将数组中对应的元素相加
array1 = np.random.randint(1, 10, 9).reshape(3, 3)
array2 = np.random.randint(1, 10, 9).reshape(3, 3)
print(array1)
print(array2)
print(np.add(array1, array2))
# multiply:数组元素相乘(对应元素相乘) 区别于矩阵乘法
print(np.multiply(array1, array2))
# diag以一维数组的形式返回方阵的对角线元素
print(np.diag(array1))
print(np.diag(array2))
# dot矩阵乘法
print(np.dot(array1, array2))
# trace计算对角线元素的和
print(np.trace(array1))
print(np.trace(array2))
# det 计算矩阵行列式
print(np.linalg.det(array1))
print(np.linalg.det(array2))
# eig 计算方阵的特征值和特征向量
a2 = np.array([[1, 2, 3], [2, 3, 4]]) # 建立一个二维数组
b2 = np.array([[1, 2, 3], [2, 3, 4]], dtype=int) # 可以输出指定数据类型
# print(np.linalg.eig(a2)) # 返回矩阵a2的特征值与特征向量
矩阵&切片
import numpy as np
# 矩阵的逆
array = np.random.randint(1, 10, 9).reshape(3, 3) # n*n的矩阵一定会有逆矩阵
# print(array)
# array2 = np.linalg.inv(array)# 生成矩阵的逆
# print(array2)
# 矩阵的乘法
# array3 = np.dot(array2, array)# 矩阵*逆矩阵=单位矩阵
# print(array3)# 单位矩阵:对角线元素为1
# 矩阵转置
# print(array.T)
# 基本运算
# print(array.sum()) # 所有元素的和
# print(array.sum(0)) # 每一列的求和
# print(array.sum(1)) # 每一行的求和
# 切片
# array = np.random.randint(1, 10, 20).reshape(4, 5)
# # array2 = np.ones(20).reshape(4, 5)# 加减时 reshape中数字与array中一样
# array2 = np.ones(20).reshape(5, 4)# 矩阵乘法a*b时,要保证a的列数等于b的行数 a:m*p b:p*n
# 切片
array = np.random.randint(1, 10, 16).reshape(4, 4)
print(array)
print("-------分割线---------")
# 取出第一行的所有值
print(array[0]) # 相当于 array[0,:]
print("-------分割线---------")
# 取第一列
print(array[:, 0])
print("-------分割线---------")
# 取第一行和第三行
print(array[0::2, :])
print("-------分割线---------")
# 取第二列和第四列
print(array[::, 1::2])
print("-------分割线---------")
# 取第一行和第三行的第二列和第四列
print(array[0::2, 1::2])
print("-------分割线---------")
# 遍历多维数组
for i in range(0, array.shape[0]):
for j in range(0, array.shape[1]):
print(array[i][j], end=" ")
print()
array = np.random.randint(1, 10, 9).reshape(3, 3)
print(array)
print(np.where(array > 5, array, 0))# 将大于5的值留下来,小于5的用0代替
print(array[2][2])