python马士兵学习笔记

2023-11-10

前言:本篇文章是作者在B站学习python马士兵视频的笔记,之前章节的内容可参考https://blog.csdn.net/qq_43511094/article/details/113062435
https://blog.csdn.net/weixin_46860149/article/details/118232264

视频传送门:https://www.bilibili.com/video/BV1wD4y1o7AS

文章目录

十一章 异常

python异常处理机制

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

python中常见的异常类型

在这里插入图片描述

# print (10/0) #ZeroDivisionError

lst = [11, 22, 33, 44]
# print(lst[4])#IndexError索引从0开始

dic = {'name': '张三', 'age': 20}
# print(dic['gender']) #KeyError

# print (num)  # NameError

# int a=20 #SyntaxError    python中的变量没有数据类型

a = int('hello')  # ValueError

traceback模块的使用

在这里插入图片描述

pycharm开发环境的调试

在这里插入图片描述


十二章 类与对象

定义python中的类

在这里插入图片描述

class Student:  # Student为类的名称(类名)由一个或多个单词组成,每个单词的首字母大写,其余小写
    native_pace = '吉林'  # 直接写在类里的变量,称为类属性

    def __init__(self, name, age):  # 初始化方法
        self.name = name  # self.name称为实体属性,进行了一个赋值的操作,将局部变量的name的值赋给实体属性   
        self.age = age

    # 实例方法
    def eat(self):
        print('学生在吃饭...')

    # 静态方法
    @staticmethod
    def method():  # 静态方法中不能加self
        print('我使用了staticmethod进行修饰,所以我是静态方法')

    # 类方法
    @classmethod
    def cm(cls):
        print('我是类方法,因为我使用了classmethod进行修饰')

    # 类之外定义的叫函数,类里定义的叫方法
    def drink():
        print('喝水')

对象的创建

在这里插入图片描述

# 创建Student类的对象
stu1 = Student('张三', 20)
stu1.eat()  # 对象名.方法名()
print(stu1.name)
print(stu1.age)

Student.eat(stu1)  # 第二种调用方式,  类名.方法名(类的对象)-->实际上就是方法定义处的self

# 输出
'''学生在吃饭...
张三
20
学生在吃饭...'''

类属性、类方法、静态方法的使用方式

在这里插入图片描述

# 类属性的使用方式
print(Student.native_pace)  # 访问类属性
stu1 = Student('张三', 20)
stu2 = Student('李四', 30)
print(stu1.native_pace)
print(stu2.native_pace)
'''输出:
吉林
吉林
吉林'''

#类方法的使用方式
Student.cm()  # 实例方法需要传实例对象,而类方法通过类名来调用
'''输出: 我是类方法,因为我使用了classmethod进行修饰'''

#静态方法的使用方式
Student.method()   # 没有默认参数,也是通过类名来调用
'''输出: 我使用了staticmethod进行修饰,所以我是静态方法'''

动态绑定属性和方法

在这里插入图片描述

class Student:  # Student为类的名称(类名)由一个或多个单词组成,每个单词的首字母大写,其余小写

    def __init__(self, name, age):
        self.name = name
        self.age = age

    def eat(self):
        print(self.name + '在吃饭')


stu1 = Student('张三', 20)
stu2 = Student('李四', 30)

# 为stu1动态绑定性别属性
stu1.gender = '女'
print(stu1.name, stu1.age, stu1.gender)
'''输出: 张三 20 女'''
print(stu2.name, stu2.age)
'''输出: 李四 30'''


# 一个Student类可以创建N多个Student类的实例对象,每个实体对象的属性值不同

def show():
    print('定义在类之外的,称函数')


# 为stu1动态绑定方法
stu1.show = show
stu1.show()

十三章 面向对象

面向对象的三大特性----封装、继承、多态

在这里插入图片描述

封装的实现方式

class Student:
    def __init__(self, name, age):
        self.name = name
        self.__age = age  # 年龄不希望在类的外部被使用,所以加了两个_

    def show(self):
        print(self.name, self.__age)


stu = Student('张三', 20)
stu.show()
# 在类外使用name
print(stu.name)
# print(stu.__age)      访问不了
print(stu._Student__age)   # 在类的外部可以通过 _类名__属性名 进行访问,但是不建议

继承及其实现方式

在这里插入图片描述

class Person(object):  # Person类继承object类
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def info(self):
        print(self.name, self.age)


class Student(Person):  # Student类继承Person类
    def __init__(self, name, age, stu_no):
        super().__init__(name, age)   # 使用super调用父类的方法
        self.stu_no = stu_no


class Teacher(Person):  # Teacher类继承Person类
    def __init__(self, name, age, teachofyear):
        super().__init__(name, age)
        self.teachofyear = teachofyear


stu = Student('张三', 20, '1001')
teacher = Teacher('李四', 30, 10)

stu.info()
teacher.info()
'''输出: 
张三 20
李四 30'''
#多继承
class A(object):
	pass
class B(object):
	pass
class C(A,B):
	pass

方法重写

在这里插入图片描述

class Person(object):  # Person类继承object类
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def info(self):
        print(self.name, self.age)


class Student(Person):  # Student类继承Person类
    def __init__(self, name, age, stu_no):
        super().__init__(name, age)
        self.stu_no = stu_no

    def info(self):  # 重写父类的方法
        super().info()  # 先执行父类的方法
        print(self.stu_no)


class Teacher(Person):  # Teacher类继承Person类
    def __init__(self, name, age, teachofyear):
        super().__init__(name, age)
        self.teachofyear = teachofyear

    def info(self):
        super().info()  # 先执行父类的方法
        print('教龄', self.teachofyear)


stu = Student('张三', 20, '1001')
teacher = Teacher('李四', 30, 10)

stu.info()
teacher.info()
'''输出: 
张三 20
1001
李四 30
教龄 10'''

Object类

在这里插入图片描述

class Student:
    def __init__(self, name, age):
        self.name = name
        self.age = age

    def __str__(self):
        return '我的名字是{0},今年{1}岁'.format(self.name, self.age)


stu = Student('张三', 20)
print(dir(stu))
print(stu)  # 默认会调用__str__()这样的方法

'''输出: 
['__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', '__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', '__weakref__', 'age', 'name']
我的名字是张三,今年20岁'''

多态

在这里插入图片描述
在这里插入图片描述

python是动态语言,它只关心这个类有没有相应的方法,像上面的Person类没有继承Animal类,但它有eat()方法

这是与java等静态语言不一样的地方

特殊方法和特殊属性

在这里插入图片描述

特殊属性

class A(object):
    pass


class B(object):
    pass


class C(A, B):
    def __init__(self, name, age):
        self.name = name
        self.age = age


# 创建C类的对象
x = C('jack', 20)  # x是C类的一个实例对象
print(x.__dict__)  # 实例对象的属性字典
print(C.__dict__)  # 类的属性字典
print('--------')
print(x.__class__)  # 输出对象所属的类
print(C.__bases__)  # 输出C类的父类类型的元素
print(C.__mro__)  # 类的层次结构
print(A.__subclasses__())  # 子类的列表

'''输出: 
{'name': 'jack', 'age': 20}
{'__module__': '__main__', '__init__': <function C.__init__ at 0x000001D9042EBDC0>, '__doc__': None}
--------
<class '__main__.C'>
(<class '__main__.A'>, <class '__main__.B'>)
(<class '__main__.C'>, <class '__main__.A'>, <class '__main__.B'>, <class 'object'>)
[<class '__main__.C'>]
'''

特殊方法

class Student:
    def __init__(self, name):
        self.name = name

    def __add__(self, other):
        return self.name + other.name

    def __len__(self):
        return len(self.name)


stu1 = Student('张三')
stu2 = Student('李四')

s = stu1 + stu2  # 实现了两个对象的加法运算(因为在Student类中编写_add__()特殊的方法)
print(s)
print(len(s))
class Person(object):
    def __new__(cls, *args, **kwargs):
        print('__new__被调用执行了,cls的id值为{0}'.format(id(cls)))
        obj = super().__new__(cls)
        print('创建对象的id值为{0}'.format(id(obj)))
        return obj

    def __init__(self, name, age):
        print('__init__被调用了,self的id值为{0}'.format(id(self)))
        self.name = name
        self.age = age


print('object这个类对象的id为{0}'.format(id(object)))
print('Person这个类对象的id为{0}'.format(id(Person)))

# 创建Person类的实例对象
p1 = Person('张三', 20)
print('p1这个Person类的实例对象的id:{0}'.format(id(p1)))

'''输出:
object这个类对象的id为140707984993104
Person这个类对象的id为1427494206928
__new__被调用执行了,cls的id值为1427494206928
创建对象的id值为1427495955328
__init__被调用了,self的id值为1427495955328
p1这个Person类的实例对象的id:1427495955328
'''

在这里插入图片描述

类的浅拷贝与深拷贝

在这里插入图片描述

class CPU:
    pass
    
class Disk:
    pass

class Computer:
    def __init__(self, cpu, disk):
        self.cpu = cpu
        self.disk = disk

# (1)变量的赋值
cpu1 = CPU()
cpu2 = cpu1
print(cpu1, id(cpu1))
print(cpu2, id(cpu2))
# (2)类的浅拷贝
print('------------')
disk = Disk()  # 创建一个Disk类对象
computer = Computer(cpu1, disk)  # 创建一个Computer类对象
# 浅拷贝
import copy

print(disk)
computer2 = copy.copy(computer)
print(computer, computer.cpu, computer.disk)
print(computer2, computer2.cpu, computer2.disk)

#深拷贝
print('------------')
computer3=copy.deepcopy(computer)
print(computer, computer.cpu, computer.disk)
print(computer3, computer3.cpu, computer3.disk)


'''输出:
<__main__.CPU object at 0x0000020638BF65E0> 2225745126880
<__main__.CPU object at 0x0000020638BF65E0> 2225745126880
------------
<__main__.Disk object at 0x0000020638BC86D0>
<__main__.Computer object at 0x0000020638C0D430> <__main__.CPU object at 0x0000020638BF65E0> <__main__.Disk object at 0x0000020638BC86D0>
<__main__.Computer object at 0x0000020638C0DC70> <__main__.CPU object at 0x0000020638BF65E0> <__main__.Disk object at 0x0000020638BC86D0>
------------
<__main__.Computer object at 0x000001F78328D430> <__main__.CPU object at 0x000001F7832765E0> <__main__.Disk object at 0x000001F7832486D0>
<__main__.Computer object at 0x000001F784ED7310> <__main__.CPU object at 0x000001F784ED7370> <__main__.Disk object at 0x000001F784ED76A0>
'''

十四章 模块

什么叫模块、模块化编程的好处

在这里插入图片描述

模块的导入

在这里插入图片描述

导入自定义的模块需要 右键当前目录,选择Mark Directory as,再选择Sources Root

以主程序方式运行

在这里插入图片描述

if __name__=='__main__':  # 只有运行当前程序时,才会执行pass代码
	pass

python中的包

在这里插入图片描述

使用import方式进行导入时,只能跟包名或模块名

使用from …import可以导入包,模块,函数,变量

python中常用的内置模块

在这里插入图片描述

第三方模块的安装与使用

在这里插入图片描述

十五章 文件操作

编码格式

在这里插入图片描述

文件读写原理

在这里插入图片描述

在这里插入图片描述

常用的文件打开模式

在这里插入图片描述

文件对象的常用方法

在这里插入图片描述

With语句

在这里插入图片描述

with open(' logo.png','rb') as src_file:
	with open('copy2logo.png','wb') as target_file:
		target_file.write(src_file.read ())

以上代码实现文件的复制

文件操作推荐使用with语句,这样不用手动去写关闭操作

目录操作

在这里插入图片描述

#OS 模块是与操作系统相关的一个模块
import os
os.system('notepad.exe')    #打开记事本
os.system('calc.exe')		#打开计算器

# 接调用可执行文件
os.startfile('C:\\Program Files\\Tencent\\QQ\\Bin\\qq.exe')

在这里插入图片描述

在这里插入图片描述

实操案例——学生信息管理系统

import os

filename = 'student.txt'


def main():
    while True:
        menu()
        choice = int(input('请选择'))
        if choice in range(0, 8):
            if choice == 0:
                answer = input('您确定要退出系统吗? y/n')
                if answer == 'y' or answer == 'Y':
                    print('感谢您使用本系统!!')
                    break  # 退出系统
                else:
                    continue
            elif choice == 1:
                insert()  # 录入学生信息
            elif choice == 2:
                search()  # 查找学生信息
            elif choice == 3:
                delete()  # 删除学生信息
            elif choice == 4:
                modify()  # 修改学生信息
            elif choice == 5:
                sort()  # 排序
            elif choice == 6:
                total()  # 统计学生总人数
            elif choice == 7:
                show()  # 显示所有学生信息


def menu():
    print("====================学生信息管理系统====================\n")
    print('--------------------功能菜单---------------------------')
    print('\t\t\t\t\t1.录入学生信息')
    print('\t\t\t\t\t2.查找学生信息')
    print('\t\t\t\t\t3.删除学生信息')
    print('\t\t\t\t\t4.修改学生信息')
    print('\t\t\t\t\t5.排序')
    print('\t\t\t\t\t6.统计学生总人数')
    print('\t\t\t\t\t7.显示所有学生信息')
    print('\t\t\t\t\t0.退出')
    print('-----------------------------------------------------')


def insert():  # 录入学生信息
    student_list = []
    while True:
        id = input('请输入ID(如1001):')
        if not id:
            break
        name = input('请输入姓名:')
        if not name:
            break

        try:
            english = int(input('请输入英语成绩:'))
            python = int(input('请输入Python成绩:'))
            java = int(input('请输入java成绩:'))
        except:
            print('输入无效,不是整数类型,请重新输入')
            continue

        # 将录入的学生信息保存到字典中
        student = {'id': id, 'name': name, 'english': english, 'python': python, 'java': java}
        # 将学生信息添加到列表中
        student_list.append(student)
        answer = input('是否继续添加? y/n')
        if answer == 'y':
            print()
            continue
        else:
            print()
            break

    # 调用save()函数
    save(student_list)
    print('学生信息录入完毕!!')


def save(lst):  # 将学生信息录入文件中
    try:
        stu_txt = open(filename, 'a', encoding='utf-8')
    except:
        stu_txt = open(filename, 'w', encoding='utf-8')
    for item in lst:
        stu_txt.write(str(item) + '\n')
    stu_txt.close()


def search():  # 查找学生信息
    student_query = []
    while True:
        id = ''
        name = ''
        if os.path.exists(filename):
            mode = input('按ID查找请输入1,按姓名查找请输入2:')
            if mode == '1':
                id = input('请输入学生ID:')
            elif mode == '2':
                name = input('请输入学生姓名:')
            else:
                print('您的输入有误,请重新输入!')
                search()
            with open(filename, 'r', encoding='utf-8') as rfile:
                student = rfile.readlines()
                for item in student:
                    d = dict(eval(item))
                    if id != '':  # 按ID查
                        if d['id'] == id:
                            student_query.append(d)
                    elif name != '':  # 按姓名查
                        if d['name'] == name:
                            student_query.append(d)
            # 显示查询结果
            show_student(student_query)
            # 清空列表
            student_query.clear()
            answer = input('是否继续查询? y/n')
            if answer == 'y' or answer == 'Y':
                continue
            else:
                break

        else:
            print('暂未保存学生信息')
            return


def show_student(lst):
    if len(lst) == 0:
        print('没有查找到学生信息,无数据显示!!!')
        return
        # 定义标题显示格式
    format_title = "{:^6}\t{:^12}\t{:^8}\t{:^10}\t{:^10}\t{:^8}"
    print(format_title.format('ID', '姓名', '英语成绩', 'Python成绩', 'Java成绩', '总成绩'))
    # 定义内容显示格式
    format_data = "{:^6}\t{:^12}\t{:^8}\t{:^8}\t{:^8}\t{:^8}"
    for item in lst:
        print(format_data.format(item.get('id'),
                                 item.get('name'),
                                 item.get('english'),
                                 item.get('python'),
                                 item.get('java'),
                                 int(item.get('english')) + int(item.get('python')) + int(item.get('java'))
                                 ))


def delete():  # 删除学生信息
    while True:
        student_id = input('请输入要删除的学生的ID:')
        if student_id != '':
            if os.path.exists(filename):  # 文件存在
                with open(filename, 'r', encoding='utf_8')as file:
                    student_old = file.readlines()
            else:  # 文件不存在
                student_old = []
            flag = False  # 标记是否删除
            if student_old:
                with open(filename, 'w', encoding='utf_8') as wfile:
                    d = {}
                    for item in student_old:
                        d = dict(eval(item))  # 将字符串转成字典
                        if d['id'] != student_id:
                            wfile.write(str(d) + '\n')  # 将不需要删除的学生信息再次写入
                        else:
                            flag = True
                    if flag:
                        print(f'id为{student_id}的学生信息已被删除')
                    else:
                        print(f'没有找到ID为{student_id}的学生信息')
            else:
                print('无学生信息')
                break
            show()  # 删除之后重新显示所有学生信息
            answer = input('是否继续删除? y/n')
            if answer == 'y' or answer == 'Y':
                continue
            else:
                break


def modify():  # 修改学生信息
    show()
    if os.path.exists(filename):  # 文件存在
        with open(filename, 'r', encoding='utf-8')as rfile:
            student_old = rfile.readlines()  # 原来的学生信息放入列表中
    else:
        return
    student_id = input('请输入要修改的学生的ID:')
    with open(filename, 'w', encoding='utf-8') as wfile:
        for item in student_old:
            d = dict(eval(item))
            if d['id'] == student_id:
                print('找到学生信息,可以进行修改了!')
                while True:
                    try:
                        d['name'] = input('请输入姓名:')
                        d['english'] = input('请输入英语成绩:')
                        d['python'] = input('请输入Python成绩:')
                        d['java'] = input('请输入java成绩:')
                    except:
                        print('您的输入有误,请重新输入!!!')
                    else:
                        break
                wfile.write(str(d) + '\n')  # 将修改后的信息写入文件
                print('修改成功!!!')
            else:
                wfile.write(str(d) + '\n')  # 将未修改的信息也写入原文件
            answer = input('是否继续修改其他学生信息? y/n')
            if answer == 'y' or answer == 'Y':
                modify()


def sort():  # 排序
    show()
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as rfile:
            student_list = rfile.readlines()
        student_new = []
        for item in student_list:
            d = dict(eval(item))
            student_new.append(d)
    else:
        return
    asc_or_desc = input('请选择:(0.升序 1.降序)')
    if asc_or_desc == '0':
        asc_or_desc_bool = False
    elif asc_or_desc == '1':
        asc_or_desc_bool = True
    else:
        print('您的输入有误,请重新输入')
        sort()
    mode = input('请选择排序方式(1.按英语成绩排序 2.按Python成绩排序 3.按Java成绩排序 0.按总成绩排序):')
    if mode == '1':
        student_new.sort(key=lambda x: int(x['english']), reverse=asc_or_desc_bool)
    elif mode == '2':
        student_new.sort(key=lambda x: int(x['python']), reverse=asc_or_desc_bool)
    elif mode == '3':
        student_new.sort(key=lambda x: int(x['java']), reverse=asc_or_desc_bool)
    elif mode == '0':
        student_new.sort(key=lambda x: int(x['english']) + int(x['python']) + int(x['java']), reverse=asc_or_desc_bool)
    else:
        print('您的输入有误,请重新输入!!!')
        sort()
    show_student(student_new)


def total():  # 统计学生总人数
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as rfile:
            students = rfile.readlines()
            if students:
                print(f'一共有{len(students)}名学生')
    else:
        print('暂未保存学生的信息!')


def show():  # 显示所有学生信息
    student_list = []
    if os.path.exists(filename):
        with open(filename, 'r', encoding='utf-8') as rfile:
            students = rfile.readlines()
        for item in students:
            student_list.append(eval(item))
        if student_list:
            show_student(student_list)
    else:
        print('暂未保存数据信息!!!')


if __name__ == '__main__':
    main()

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

python马士兵学习笔记 的相关文章

  • 给vim增加Vundle和NERDTree插件

    先给vim加了两个插件 windows下的插件应该放在 Users 用户名 vim目录下 然后clone一下vundle cd USERPROFILE git clone https github com gmarik Vundle vim
  • [管理与领导-71]:IT基层管理者 - 辅助技能 - 4- 职业发展规划 - 职业情绪管理

    目录 前言 一 迟到 不积极的三种情况 二 工作动机 动力模型 2 1 兴趣 能力 价值感模型 2 2 动机模型 三 常见的负面的职业情绪 四 应对措施 4 1 职业中应对焦虑的策略 4 2 职业中应对厌倦的策略 4 3 职业中应对失落的策
  • 数组扁平化

    1 一维数组扁平化 let result for let i 0 i lt arr2 length i result result concat arr2 i console log result 1 2 3 4 5 6 2 多级数组 1
  • Java中Thread类run(),start()区别

    转自 Java中Thread类run start 区别 下文讲述Thread类中run start 方法的不同之处说明 如下所示 run start 方法功能的区别 1 start 方法用于启动线程 run方法只是Thread子类的一个普通
  • mysql数据库迁移到瀚高数据库,包含数据迁移、sql语法、服务启动、部署、tomcat问题整理

    文章目录 1 数据库迁移 2 数据库设置主键自增 2 1 数据库字段问题 2 2 存在即更新 2 3 清空数据表 2 4 瀚高数据库查询过程中显示转换 2 5 mybatis插入一条数据返回自增的主键值 2 6 瀚高数据库服务无法启动 3
  • 《数值分析》-- 雅可比迭代法、高斯—塞德尔迭代法

    文章目录 一 基本迭代法的格式及收敛性 1 1 迭代法思想 1 2 向量序列收敛的定义 二 迭代法的收敛与发散 三 雅可比迭代法和高斯赛德尔迭代法 3 1 雅可比迭代法 3 2 高斯 赛得尔 Gauss Seidel 迭代法 四 迭代法的收
  • python无法安装第三方库read time out_(python pip安装第三方库超时问题(raise ReadTimeoutErrorself._pool, None, 'Read time...

    python pip安装第三方库超时问题 raise ReadTimeoutErrorself pool None Read timed out pip工具安装 百度经验链接 pip安装及环境变量配置 pip下载超时处理 aise Read
  • Apache Shiro 简介

    本文转载自 点击打开链接 1 1 简介 Apache Shiro是Java的一个安全框架 目前 使用Apache Shiro的人越来越多 因为它相当简单 对比Spring Security 可能没有Spring Security做的功能强大
  • ztree 修改样式_zTree样式修改

    ztree挺好用的 不过公司美工设计的行政树图稿一般都比ztree原生的样式要好看的多 所以只能自己单独对样式进行修改 目前样式倒是修改好了 只能不能根据层级动态匹配样式 每个层级的被选中样式需要对两个属性单独设置 具体修改地方下面代码中有
  • java里%是什么_java里"."是什么意思?

    展开全部 lt 数学意义 在数字没有溢出的前提下 对于正数和负数 左移一位都相当于乘以2的1次方 左移n位就相当于乘以2的n次方 计算 3 lt lt 2 3 lt lt 2 则是将数字3左移2位 1 首先把3转换为二进制数字0000 00
  • python机器学习手写算法系列——逻辑回归

    从机器学习到逻辑回归 今天 我们只关注机器学习到线性回归这条线上的概念 别的以后再说 为了让大家听懂 我这次也不查维基百科了 直接按照自己的理解用大白话说 可能不是很严谨 机器学习就是机器可以自己学习 而机器学习的方法就是利用现有的数据和算
  • SQL11 高级操作符练习(1)

    描述 题目 现在运营想要找到男性且GPA在3 5以上 不包括3 5 的用户进行调研 请你取出相关数据 示例 user profile id device id gender age university gpa 1 2138 male 21
  • 牛客SQL练习一

    1 题目描述 查找最晚入职员工的所有信息 CREATE TABLE employees emp no int 11 NOT NULL birth date date NOT NULL first name varchar 14 NOT NU
  • springboot自定义favicon.ico

    先上效果图 1 在application yml文件中必须修改配置 spring mvc favicon enabled false spring mvc favicon enabled false 2 在static文件下 ico转化地址
  • LeetCode-Python-1248. 统计「优美子数组」(数组 + 数学)

    给你一个整数数组 nums 和一个整数 k 如果某个子数组中恰好有 k 个奇数数字 我们就认为这个子数组是 优美子数组 请返回这个数组中 优美子数组 的数目 示例 1 输入 nums 1 1 2 1 1 k 3 输出 2 解释 包含 3 个
  • base64格式图片展示

    后端发图片 为base64格式的 前端接收后页面展示图片 处理方法 let imageData data image png base64 res data image 后端传来数据 如果base64位图片没有带前面得头 data imag
  • clickhouse索引原理介绍

    clickhouse本身支持很多表引擎 这里只介绍其中最常用的MergeTree引擎 建表语句 name1 type1 DEFAULT MATERIALIZED ALIAS expr1 TTL expr1 name2 type2 DEFAU
  • cannot import name ‘Merge‘ from ‘keras.layers‘解决方法

    首先根据报错提示 找到对应的文件 看看Merge是否在keras layers里 发现现在已经改成下图的了 直接复制粘贴到代码里即可 报错提示为王 别再扎错方向
  • 数据清洗的基本流程_数据分析几步走?告诉你全面系统的流程

    通过对 谁说菜鸟不会数据分析 的阅读 我们知道数据分析的一般流程为 明确分析目标 一切以目标为导向 确定分析思路 数据获取 数据处理 清洗 转化 提取 计算等 数据分析及可视化 报表撰写 这就是数据分析的一般流程 本章我们就讲一下各个流程中
  • MySQl数据库必会sql语句(提升版)

    原文链接 http blog csdn net qq 32059827 article details 51778816 这一篇属于加强版 问题和sql语句如下 创建users表 设置id name gender sal字段 其中id为主键

随机推荐