Python基础语法1
目录
1、认识Python
1.1、计算机
1.2、编程
1.3、编程语言的类别
1.4、Python背景
1.5、Python的应用场景
1.6、Python的优缺点
1.7、Python前景
1.8、Python 环境
2、常量和表达式
3、变量和类型
3.1、定义变量
3.2、使用变量
3.3、变量的类型
3.3.1、整形
3.3.2、浮点数
3.3.3、字符串
3.3.4、布尔类型
3.3.5、其他类型
3.3.6、类型的作用
3.4、动态类型特性
4、注释
4.1、注释的作用
4.2、注释的语法
4.3、注释的规范
5、输入和输出
5.1、控制台输出
5.2、控制台输入
6、运算符
6.1、算数运算符
6.2、关系运算符
6.3、逻辑运算符
6.4、赋值运算符
6.5、其他运算符
1、认识Python
1.1、计算机
很多老一辈的人,管下面这个叫做计算机。然而,它只是 "计算器",和计算机是有很大区别的。
现在我们所说的计算机,不光能进行算术运算,还能进行逻辑判断,数据存储,网络通信等等功能,以至于可以自动的完成非常复杂的工作。以下这些都可以称为 "计算机" 。
总的来说,一台计算机, 主要由以下这几个重要的组件构成:
1、CPU(相当于大脑,可以进行算数运算与逻辑判断等)
2、存储器 (内存, 硬盘等),内存的存储空间较小,访问速度较快;外存的存储空间大,但访问速度慢。内存的成本也比外存的成本高。内存上的数据容易丢失(断电数据就没有了),外存上的数据能够持久化存储(断电数据也在)。这里的持久化存储是相对内存来讲的,一般机器硬盘的存储时间也就是几年到几十年。
3、输入设备 (键盘, 鼠标等)
4、输出设备 (显示器, 音响等)
有的设备即是输入设备,也是输出设备,比如:触摸屏和网卡等。
以上的组成结构, 称为 "冯诺依曼体系结构"。
芯片主要指的就是 CPU。显卡(GPU)是和 CPU 类似的计算芯片,CPU 是 "通用计算芯片", 可以处理各种场景下的各种问题。可以在各个行业各个领域贡献力量。GPU 是 "专用计算芯片", 特别擅长处理浮点数运算。
换个角度看,人脑也能算术运算,能逻辑判断,能数据存储,能输入输出..... 也可以视为是一个广 义的计算机。
1.2、编程
计算机需要硬件赋予之躯体,也需要软件赋予之灵魂。
"软件" (或者叫做程序),指挥了计算机要按照什么样的规则来执行任务。
制作软件,就是在明确这个软件要完成什么样的任务,这个过程就称为 "编程"。
编程本身,并不是一件很容易的事情,因此就衍生出了一个专门负责编程的职业,也就是程序员。
因为计算机不能直接理解人类的语言。程序员进行编程的过程中,需要使用一个专门的方式和计算机沟通,就是 "编程语言"。 使用编程语言编写软件的具体过程,就称为 "软件开发",俗称 "敲代码"。
1.3、编程语言的类别
编程语言大体可以分成三个大类
1、机器语言
2、汇编语言
3、高级语言
其中机器语言和汇编语言都是更贴近计算机的,人类理解起来并不容易。因此目前程序员使用的编程语言主要是高级语言。
高级语言的种类有很多很多,以下列出的都是实际开发中常用的编程语言。链接:TIOBE
从这个排名中也可以看出Python很出名。
1.4、Python背景
吉多·范罗苏姆(Guido van Rossum) 是一个荷兰程序员。在1989 年圣诞节的时候(当时 33 岁),因为在家里待着无聊,为了打发时间,开始了 Python 的开发。第一个正式版本发布于1991年。
1991 年是一个神奇的年份。Python,万维网,Linux,Vim,Qt,第一台笔记本电脑,都诞生于 1991年。
1.5、Python的应用场景
经历了多年的发展,Python 目前是一个应用场景非常广泛的编程语言。
1、科学计算和数据分析
2、Web 开发(搭建网站)
3、自动化运维
4、人工智能
5、爬虫程序
5、自动化测试
等等。
1.6、Python的优缺点
Python是用C语言编写的编程语言。
优点:
1、语法言简意赅, 容易上手。
2、功能强大,用途广泛。
3、生态丰富,具有海量的成熟第三方库。
4、方便调用 C/C++ 编写的代码进行 高性能/系统级操作
缺点:
1、执行效率比较弱。
2、对于多核心并发程序支持偏弱。
3、动态类型系统对于大型项目不太友好。
1.7、Python前景
虽然 Python 的应用场景很多,但是纯粹使用 Python 的岗位是比较少见的。
程序员找工作的网站主要有:拉钩、boss直聘、牛客网等。
Python在实际开发中,更多的是扮演“辅助”的角色。
更常见到的情况是,把 Python 作为一个辅助性质的语言。在工作中,Python 更像是一个工具,需要用到的时候随手拿起来就用,能够方便的解决不少问题。
Python 和其他的编程语言本质上并没有啥区别。并不存在某个场景是 "非得 Python 能做,其他语 言做不了" 这样的情况。
1.8、Python 环境
要想能够进行 Python 开发,就需要搭建好 Python 的环境。
需要安装的环境主要是两个部分:
运行环境: Python
开发环境: PyCharm
下载安装软件,最靠谱的方法就是去官网上下载。
关于 Python 版本的补充:现在主流使用的 Python 版本是 Python 3 系列。但是一些比较老的项目, 可能还在使用 Python 2。3系列和2系列之间的语法还是存在不小差别的。接下来主要是依Python 3 系列展开。
关于如何具体搭建环境不再多讲。如果不会搭建环境,可以自行搜索Python环境搭建的有关视频或文章。
2、常量和表达式
我们可以把 Python 当成一个计算器,来进行一些算术运算。例如:
print(1 + 2 - 3)
print(1 + 2 * 3)
print(1 + 2 / 3)
运行结果为:
编程中,一般没有四舍五入的规则。浮点数在IEEE754标准下,在内存中表示浮点数的时候,可能存在微小的误差。
注意: print 是一个 Python 内置的函数,这个稍后详细介绍。可以使用 + - * / ( ) 等运算符进行算术运算,先算乘除,后算加减。运算符和数字之间,可以没有空格,也可以有多个空格。但是一般习惯上写一个空格(比较美观)。代码的美观也是很重要的。
形如 1 + 2 - 3 这样是算式,在编程语言中称为表达式,算式的运算结果,称为表达式的返回值
其中 1, 2, 3 这种称为字面值常量,+ - * / 这种称为运算符或者操作符。
注意:熟悉 C / Java 的可能认为,2 / 3 结果为 0 (小数部分被截断)。但是在 Python 中得到的结果则是一个小数。更符合日常使用的直觉。
例如:给定四个分数,67.5, 89.0, 12.9, 32.2 ,编写代码,求这四个分数的平均数。
print( (67.5 + 89.0 + 12.9 + 32.2) / 4 )
3、变量和类型
有的时候,我们需要进行的计算可能更复杂一些,需要把一些计算的中间结果保存起来。这个时候就需要用到变量。
例如:给定四个分数,67.5, 89.0, 12.9, 32.2 , 编写代码,求这四个分数的方差。
avg = (67.5 + 89.0 + 12.9 + 32.2) / 4
total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg) ** 2
result = total / 3
print(result)
注意:
1、avg, total, result 均为变量。
2、** 在 Python 中表示乘方运算。** 2 即为求平方。
变量可以视为是一块能够容纳数据的空间。这个空间往往对应到 "内存" 这样的硬件设备上。
衡量内存的一个重要指标就是内存空间的大小,比如我的电脑内存是 16GB。这个数字越大,意味着内存的存储空间就越大,能够存放的数据(变量) 就越多。
3.1、定义变量
a = 10
创建变量的语句非常简单, 其中:
a 为变量名。当我们创建很多个变量的时候,就可以用名字来进行区分。
= 为赋值运算符,表示把 = 右侧的数据放到 = 左侧的空间中。
注意: 变量的名字要遵守一定规则。
硬性规则(务必遵守):
1、变量名由数字字母下划线构成。
2、数字不能开头。
3、变量名不能和 "关键字" 重复。
4、变量名大小写敏感。num 和 Num 是两个不同的变量名。
软性规则(建议遵守) :
1、变量名使用有描述性的单词来表示,尽量表达出变量的作用。
2、 一个变量名可以由多个单词构成,长一点没关系,但是含义要清晰。
3、当变量名包含多个单词的时候,建议使用 "驼峰命名法"。形如 totalCount , personInfo 这种,除了首个单词外,剩余单词首字母大写。
4、除了驼峰命名法外,还有“蛇形命名法”,单词与单词之间使用下划线_来进行分隔。例如:person_info,total_count。
在公司里开发商业程序,一般公司都会有明确的编码规范。
数学上,变量通常使用 x, y, z 这种简单的英文字母或者拉丁字母表示。但是在编程中不建议这样使 用。原因是编程中,一个程序里通常会同时创建出很多个变量,如果只是使用单个字母表示,在变量多了的时候,就很难记住哪个变量是干啥的,从而给维护程序带来了一定的困难,因此我们更建议使用带有明确描述性的名字,来表示变量的用途。
3.2、使用变量
a = 10
print(a)
a = 20
print(a)
注意: 在 Python 中,修改变量也是使用 = 运算,看起来和定义变量没有明显区别。
首次对变量进行设置值叫创建变量(初始化)。后续再对变量的值进行修改叫赋值。
当然,也可以用一个变量的值赋给另外一个变量。例如:
a = 10
b = 20
a = b
print(a)
print(b)
3.3、变量的类型
变量里面存储的不仅仅可以是数字,还可以存储其它种类的数据。为了区分不同种类的数据,我们引入了 "类型" 这样的概念。
注意:和 C++ / Java 等语言不同,Python 变量的类型不需要显式指定,而是在赋值的时候确定的。变量的类型只依靠初始化语句,根据初始化的值的类型来进行确定。
3.3.1、整形
a = 10
print(type(a))
注意:type 和 print 类似,也是 python 内置的函数。可以使用 type 来查看一个变量的类型。
注意:和 C++ / Java 等语言不同,Python 的 int 类型变量表示的数据范围是没有上限的。只要内存足够大,理论上就可以表示无限大小的数据。因为Python的int是可以根据要表示的数据的大小,自动扩容,因此像long short等这种类型在Python中也就不存在了。
Python设计的一种理念:解决一个问题,只提供一个方案。
3.3.2、浮点数
a = 0.5
print(type(a))
注意:和 C++ / Java 等语言不同,Python 的小数只有 float 一种类型,没有 double 类型。但是实际上Python 的 float 就相当于 C++ / Java 的 double,表示双精度浮点数。
关于单精度浮点数和双精度浮点数的问题,我们此处不做过多讨论。大家只要知道,相比于单精 度浮点数,双精度浮点数占用的内存空间更多,同时表示的数据精度更高即可(大概精确到小数点后 15 位)。
3.3.3、字符串
a = 'hello'
print(type(a))
使用 ' ' 或者 " " 引起来的,称为 字符串。
注意:在 Python 中,单引号构成的字符串和双引号构成的字符串,'hello'和"hello"没有区别,完全等价的。
在Python中红色的波浪线表示错误,黄色的表示警告,绿色的表示提示,提示不代表有错误。
可以使用 len 函数来获取字符串的长度
a = 'hello'
print(len(a))
可以使用 + 针对两个字符串进行拼接,也就是把后一个字符串拼接到前一个字符串的尾部。例如:
a = 'hello'
b = 'world'
print(a + b)
运行结果为:
此处是两个字符串相加。不能拿字符串和整数或浮点数相加。
如果字符串中包含了双引号,表示该字符串可以使用单引号引起来;如果字符串里面包含了单引号,表示字符串就可以使用双引号引起来;如果字符串中既有单引号又有双引号,Python中还有一种表示此类字符串的方法就是使用三引号来表示,有两种形式:''' ''' 或""" """
字符串作为开发中最常用到的数据类型,支持的操作方式也是非常丰富的。感兴趣的可以自行查阅
3.3.4、布尔类型
布尔类型是一个特殊的类型,取值只有两种,True (真) 和 False (假)。
a = True
print(type(a))
b = False
print(type(b))
布尔类型在咱们后续进行逻辑判断的时候,是非常有用的。
3.3.5、其他类型
除了上述类型之外,Python 中还有 list, tuple, dict, 自定义类型等等。我们后续再介绍。
在Python中报错有两种情况:
1、语法错误。在程序运行之前,Python解释器就可以把错误给识别出来。
2、运行错误。在程序执行之前是识别不了的,必须要执行到对应的代码,才能发现问题。
3.3.6、类型的作用
类型决定了数据在内存中占据多大空间。例如 float 类型在内存中占据 8 个字节
类型其实约定了能对这个变量做什么样的操作。例如 int / float 类型的变量,可以进行 + - * / 等操作。而 str 类型的变量,只能进行 + (并且行为是字符串拼接),不能进行 - * / ,但是还能使用 len 等其他操作。
总结:类型系统其实是在对变量进行 "归类"。相同类型的变量(数据) 往往具有类似的特性和使用规则。
3.4、动态类型特性
在 Python 中,一个变量是什么类型,是可以在 "程序运行" 过程中发生变化的,这个特性称为动态类型。例如:
a = 10
print(type(a))
a = 'hello'
print(type(a))
在程序执行过程中,a 的类型刚开始是 int,后面变成了 str。C++/Java 这样的语言则不允许这样的操作。一个变量定义后类型就是固定的了,这种特性则称为静态类型
一个编程语言是否是动态类型,只取决于运行时,类型是否发生改变。不取决于变量定义的时候是否声明类型。
Python作为一个动态类型的语言,在定义变量时,也是可以写类型的,例如:
a:int=10
print(type(a))
a:str='hello'
print(type(a))
在编程中“灵活”这个词往往是“贬义”,因为灵活更容易出错。相比之下,静态类型的语言还是更好一些。
动态类型特性是一把双刃剑:
1、对于中小型程序,可以大大的节约代码量(比如写一段代码就可以同时支持多种类型)。
2、对于大型程序,则提高了模块之间的交互成本。(程序猿 A 提供的代码难以被B理解)。
4、注释
4.1、注释的作用
注释是一种特殊的代码,它不会影响到程序的执行,但是能够起到解释说明的作用,能够帮助程序员理解程序代码的执行逻辑。写代码是一件比较烧脑的事情,读代码同样也非常烧脑。相比于一板一眼的代码,一些口语化的描述能更好的帮助程序猿理解程序。
例如:
# 计算 4 个数字 67.5, 89.0, 12.9, 32.2 的方差
avg = (67.5 + 89.0 + 12.9 + 32.2) / 4
total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg) ** 2
result = total / 3
print(result)
形如上述代码,如果没有注释,直接阅读,是不容易直接理解到代码的含义是计算方差,但是通过加了一行注释解释一下,就让人一目了然了。
4.2、注释的语法
Python 中有两种风格的注释。
注释行:使用 # 开头的行都是注释。#开头的注释,一般都是写在要注释的代码的上面,也有少数情况写在注释代码的右侧,例如:
# 这是一行注释
文档字符串:使用三引号引起来的称为 "文档字符串",也可以视为是一种注释。可以包含多行内容,一般放在文件/函数/类的开头。""" 或者 ''' 均可 (等价)。
例如:
"""
这是文档字符串
这是文档字符串
"""
4.3、注释的规范
1、内容准确:注释内容要和代码一致,匹配,并在代码修改时及时更新。
2、篇幅合理:注释既不应该太精简,也不应该长篇大论。
3、使用中文:一般中国公司都要求使用中文写注释,外企另当别论。
4、积极向上:注释中不要包含负能量。
5、输入和输出
程序需要和用户进行交互:
1、用户把信息传递给程序的过程,称为 "输入"。
2、程序把结果展示给用户的过程,称为 "输出"。
输入输出的最基本的方法就是控制台,用户通过控制台输入一些字符串,程序再通过控制台打印出一些字符串。PyCharm 运行程序,下方弹出的窗口就可以视为是控制台。对于机械的操作面板,就叫控制台,控制台上会有一些按钮,开关、操作杆等。
输入输出的最常见方法是图形化界面。如我们平时用到的 QQ,浏览器,steam 等,都不需要用户输入命令,而只是通过鼠标点击窗口点击按钮的方式来操作。
Python 当然也可以用来开发图形化界面的程序,但是图形化程序开发本身是一个大话题,暂时不做介绍。
5.1、控制台输出
Python 使用 print 函数输出到控制台。例如:
print('hello')
不仅能输出一个字符串,还可以输出一个其他类型的变量。例如:
a = 10
print(a)
b = True
print(b)
更多的时候,我们希望能够输出的内容是混合了字符串和变量的。例如:
num = 10
print(f'num = {num}')
注意:
1、使用 f 作为前缀的字符串,称为 f-string。
2、里面可以使用 { } 来内嵌一个其他的变量或表达式。
Python 中还支持其他的格式化字符串的方法,此处只了解这个最简单的即可,其他的暂时不做介绍。
5.2、控制台输入
python 使用 input 函数,从控制台读取用户的输入。例如:
num = 0
num = input('请输入一个整数: ')
print(f'你输入的整数是 {num}')
注意:input 的参数相当于一个 "提示信息",也可以没有。input 的返回值就是用户输入的内容,是字符串类型。
例如:
a = input('请输入第一个整数: ')
b = input('请输入第二个整数: ')
print(f'a + b = {a + b}')
运行结果:
此处的结果是字符串拼接,不是算术运算。如果要想进行算术运算,需要先转换类型。例如:
a = input('请输入第一个整数: ')
b = input('请输入第二个整数: ')
a = int(a)
b = int(b)
print(f'a + b = {a + b}')
运行结果为:
通过int( )把变量转成了int 类型,类似的,使用 float( ), bool( ), str( ) 等可以完成对应的类型转换。
例如:输入 4 个小数,求 4 个小数的平均值。
a = input('请输入第一个数字: ')
b = input('请输入第二个数字: ')
c = input('请输入第三个数字: ')
d = input('请输入第四个数字: ')
a = float(a)
b = float(b)
c = float(c)
d = float(d)
avg = (a + b + c + d) / 4
print(f'平均值: {avg}')
此处为了输入 4 个数字,执行了四次 input。如果是读取任意多个数字怎么办呢? 这个时候就需要用到循环了,后面再介绍。
6、运算符
6.1、算数运算符
像 + - * / % ** // 这种进行算术运算的运算符, 称为 算术运算符。先算乘方,然后是乘除,最后再算加减;如果想要修改默认的运算顺序,就需要加上()。
注意:/ 中不能用 0 作为除数。否则会抛出异常,例如:
print(10 / 0)
运行结果为:
异常:是编程语言中的一种常见机制,表示程序运行过程中,出现了一些 "意外情况",导致程序不能继续往下执行了。
在一些编程语言中,除整数零会抛出异常,除浮点数零会得到一个无穷大。在Python中都认为是除零异常。
注意:整数 / 整数 结果可能是小数,而不会截断。例如:
print(1 / 2)
注意:% 不是 "百分数",而是求余数。例如:
print(7 % 2)
注意:** 是求乘方。不光能算整数次方,还能算小数次方。例如:
print(4 ** 2)
print(4 ** 0.5)
注意:// 是取整除法(也叫地板除)。整数除以整数,结果还是整数(舍弃小数部分,并向下取整。不是四舍五入)。例如:
print(7 // 2)
print(-7 // 2)
6.2、关系运算符
像 < <= > >= == != 这一系列的运算符称为关系运算符,它们是在比较操作数之间的关系。
其中:
<=:是 "小于等于"
>=:是 "大于等于"
==:是 "等于"
!=:是 "不等于"
如果关系符合,则表达式返回 True。如果关系不符合,则表达式返回 False。例如:
a = 10
b = 20
print(a < b)
print(a <= b)
print(a > b)
print(a >= b)
print(a == b)
print(a != b)
关系运算符不光针对整数或者浮点数进行比较,还能针对字符串进行比较。例如:
a = 'hello'
b = 'world'
print(a < b)
print(a <= b)
print(a > b)
print(a >= b)
print(a == b)
print(a != b)
针对中文进行字符串大小的比较是没有意义的。
注意:直接使用 == 或者 != 即可对字符串内容判定相等(这一点和 C / Java 不同)。字符串比较大小,规则是 "字典序"。
关于字典序:想象一个英文词典,上面的单词都是按照字母顺序排列。如果首个字母相同,就比较第二个字母(就比如著名单词 abandon),我们认为一个单词在词典上越靠前,就越小。越靠后,就越大。
对于布尔类型进行比较时,此时就会把True当成1,False当成0。
例如:
a=1
b=True
print(a==b)c=1.0
print(b==c)
对于浮点数来说,不要使用 == 判定相等。例如:
print(0.1 + 0.2 == 0.3)
运行结果为:
注意:浮点数在计算机中的表示并不是精确的,在计算过程中,就容易出现非常小的误差。
例如:
print(0.1)
print(0.2)
print(0.3)
print(0.1 + 0.2)
运行结果为:
可以看到,0.1 + 0.2 的结果并非是 0.3,而是带了个小尾巴。虽然这个尾巴非常小了,仍然会导致 == 的结果为 False。不止是 Python 如此,主流编程语言都是如此。这个是 IEEE754 标准规定的浮点数格式所引入的问题。此处我们不做过多讨论。
正确的比较方式:不再严格比较相等了,而是判定差值小于允许的误差范围。例如:
a = 0.1 + 0.2
b = 0.3
#Python中支持这种连续比较的写法
print(-0.000001 < (a - b) < 0.000001)
实际工程实践中,误差在所难免,只要保证误差在合理范围内即可。
6.3、逻辑运算符
像 and or not 这一系列的运算符称为逻辑运算符。
and:并且。两侧操作数均为 True,最终结果为 True,否则为 False (一假则假)。
or:或者。两侧操作数均为 False,最终结果为 False,否则为 True(一真则真)。
not:逻辑取反。操作数本身为True,则返回 False,本身为 False,则返回 True。
例如:
a = 10
b = 20
c = 30
print(a < b and b < c)
print(a < b and b > c)
print(a > b or b > c)
print(a < b or b > c)
print(not a < b)
print(not a > b)
特殊写法:a < b and b < c 这个操作等价于 a < b < c ,这个设定和大部分编程语言都不相同。
和其他编程语言类似,Python也存在短路求值的规则。
1、对于 and,如果左侧表达式为 False,则整体一定为 False,右侧表达式不再执行。
2、对于 or,如果左侧表达式为 True,则整体一定为 True,右侧表达式不再执行。
例如:
print(10 > 20 and 10 / 0 == 1)
print(10 < 20 or 10 / 0 == 1)
上述代码没有抛出异常,说明右侧的除以 0 操作没有真正执行。
6.4、赋值运算符
= 表示赋值,这个我们已经用过很多次了,注意和 == 区分 。= 除了基本的用法之外,还可以同时针对多个变量进行赋值。
链式赋值:一般不建议写链式赋值。
a = b = 10
多元赋值:
a, b = 10, 20
例如:交换两个变量
基础写法
a = 10
b = 20
tmp = a
a = b
b = tmp
基于多元赋值
a = 10
b = 20
a, b = b, a
复合赋值运算符,Python 还有一些复合赋值运算符。例如:+= -= *= /= %=。其中a+=1等价于a=a+1其他复合赋值运算符也是同理。
例如:
a = 10
a = a + 1
print(a)
b = 10
b += 1
print(b)
注意:像 C++ / Java 中, 存在 ++ -- 这样的自增或自减运算符。Python 中则不支持这种运算,如果需要使用,则直接使用 += 1 或者 -= 1。
写++a和--a之所以没有语法报错是因为Python解释器把+当成了正号,把-当成了负号。++a与--a是相等的,因为负负得正。但是写后置++和--都是会报错的。
++ --最大的问题就是容易分不清前置和后置的区别,这一点 Python 语法在设计的时候就进行了规避,避免出现这种不直观,并且容易混淆的语法。
6.5、其他运算符
除了上述之外,Python 中还有一些运算符,比如:身份运算符 (is, is not),成员运算符 (in, not in),位运算符 ( & | ~ ^ >) 等。此处咱们暂时不介绍。
注:在Python中,一个语句写完后,可以加上分号也可以不加分号,但是通常是不加的。如果把多个语句写到同一行了,这个时候语句之间是要加上分号的,但是这种写法是不推荐的。
相关文章:
Python基础语法1
目录 1、认识Python 1.1、计算机 1.2、编程 1.3、编程语言的类别 1.4、Python背景 1.5、Python的应用场景 1.6、Python的优缺点 1.7、Python前景 1.8、Python 环境 2、常量和表达式 3、变量和类型 3.1、定义变量 3.2、使用变量 3.3、变量的类型 3.3.1、整形 3.3…...
深度学习中多机训练概念下的DP与DDP
在进行单机多卡/多机多卡训练时,通常会遇到DP与DDP的概念,为此基于kimi大模型对二者的差异进行梳理。使用DP/DPP的核心是数据并行,也就是根据显卡数量对数据集进行分治,每一个显卡都有一个独立完整的模型和一个局部数据。在多个显…...
设计模式(结构型)-桥接模式
目录 摘要 定义 类图 角色 具体实现 优缺点 优点 缺点 使用场景 使用案例 JDBC 和桥接模式 总结 摘要 在软件开发领域,随着系统规模和复杂性的不断攀升,如何设计出具有良好扩展性、灵活性以及可维护性的软件架构成为关键挑战。桥接模式作为一…...
精品推荐 | 湖仓一体电商数据分析平台实践教程合集(视频教程+设计文档+完整项目代码)
精品推荐,湖仓一体电商数据分析平台实践教程合集,包含视频教程、设计文档及完整项目代码等资料,供大家学习。 1、项目背景介绍及项目架构 2、项目使用技术版本及组件搭建 3、项目数据种类与采集 4、实时业务统计指标分析一——ODS分层设计与数…...
【LangChain少样本提示工程实战】FewShotPromptTemplate原理与应用解析——附运行代码
目录 引言 重点提炼 一、FewShotPromptTemplate作用 1. 整合示例与模板,构建结构化提示 2. 引导模型理解任务逻辑 3. 提升少样本场景下的模型性能 4. 支持动态示例选择(扩展功能) 5. 与其他模块…...
基于LSTM的文本分类3——模型训练
前言 之前已经完成了模型搭建和文本数据处理,现在做一下模型训练。 源码 # -*- coding: UTF-8 -*- import numpy as np import torch import torch.nn as nn import torch.nn.functional as F from sklearn import metrics # 导入评估指标 import time from uti…...
【JS】关于原型/原型链
本文会讲解什么是原型,什么是原型链,以及查找原型的方法,最后会实现一个函数:判断某对象是否有某属性。 定义 原型:函数都有prototype属性,称作原型/原型对象 原型可以放一些方法和属性,共享…...
猫咪如厕检测与分类识别系统系列【五】信息存储数据库改进+添加猫咪页面制作+猫咪躯体匹配算法架构更新
前情提要 家里养了三只猫咪,其中一只布偶猫经常出入厕所。但因为平时忙于学业,没法时刻关注牠的行为。我知道猫咪的如厕频率和时长与健康状况密切相关,频繁如厕可能是泌尿问题,停留过久也可能是便秘或不适。为了更科学地了解牠的如…...
k8s的配置文件总结
在 Kubernetes 中,配置文件 是定义集群资源的核心,通常以 YAML 或 JSON 格式编写。以下是 Kubernetes 中关键的配置文件类型及其作用: 1. 核心工作负载配置 (1) Deployment • 用途:定义无状态应用的 Pod 副本管理策略ÿ…...
插值算法 - 最近邻插值实现
目录 1. 导入必要的库 2. nearest_neighbor_interpolation 3. 测试代码 数学原理 完整代码 本文实现了基于最近邻插值算法的图像缩放功能。 它使用 Python 编写,主要依赖于NumPy和PIL(Python Imaging Library)库。 NumPy用于高效的数值计算,而PIL仅用于图像的加载和…...
QEMU源码全解析 —— 块设备虚拟化(19)
接前一篇文章:QEMU源码全解析 —— 块设备虚拟化(18) 本文内容参考: 《趣谈Linux操作系统》 —— 刘超,极客时间 《QEMU/KVM源码解析与应用》 —— 李强,机械工业出版社 《KVM实战 —— 原理、进阶与性能调优》—— 任永杰 程舟,机械工业出版社 特此致谢! QEMU启动…...
常见的归一化(Normalization)方法
本文详解深度学习中常见的归一化方法。 【归一化是将数据按比例缩放,使之落入一个特定的区间】目录 1. 批量归一化(Batch Normalization,BN)1.1 数学原理1.2 代码示例 2. 层归一化(Layer Normalization,LN&…...
架构师面试(二十九):TCP Socket 编程
问题 今天考察网络编程的基础知识。 在基于 TCP 协议的网络 【socket 编程】中可能会遇到很多异常,在下面的相关描述中说法正确的有哪几项呢? A. 在建立连接被拒绝时,有可能是因为网络不通或地址错误或 server 端对应端口未被监听&#x…...
【高性能缓存Redis_中间件】二、redis进阶 高级特性及应用
一、前言 在第一篇文章中,我们已经对 Redis 消息队列有了基础的认识,掌握了其基本使用方法。然而,在实际的复杂业务场景中,仅仅运用基础功能是远远不够的。本篇文章将深入探讨 Redis 消息队列的高级特性,如消息确认机…...
vs2022 pcl1.15.0注意点
pcl1.15.0的版本变化很大,其中有一个地方需要设置成如下图所示 如果不设置生成的时候可能有以下错误: 严重性 代码 说明 项目 文件 行 禁止显示状态 详细信息 错误 C1189 #error: "Potential runtime error due to…...
React Router路由
例子 // 创建Router实例对象 const router createBrowserRouter([{path:/login,element:<div>我是登录</div>},{path:/article,element:<div>我是文章</div> }])在jsx中配置一个RouterProvider组件 绑定 router{router} 常规的组件配置...
深度学习(一)
(Ⅰ)神经网络和深度学习 一,ReLU激活函数 ReLU(Rectified Linear Unit)函数,输入大于0时,直接输出该值;输入小于0时,输出0 代码实现: 图中的每个节点都可以是ReLU激活函数的一部分 二,循环神经…...
【LeetCode 热题100】二叉树遍历入门:从中序遍历到层序与右视图(力扣94 / 102/199)(Go语言版)
🌳 二叉树遍历入门:从中序遍历到层序与右视图 本文涵盖 LeetCode 上的三道基础但极具代表性的二叉树遍历题: 二叉树的中序遍历 二叉树的层序遍历 二叉树的右视图 通过这些题目,我们将从 DFS 到 BFS,深入理解如何处理…...
Tauri 2.3.1+Leptos 0.7.8开发桌面应用--Sqlite数据库的写入、展示和选择删除
在前期工作的基础上(Tauri2Leptos开发桌面应用--Sqlite数据库操作_tauri sqlite-CSDN博客),尝试制作产品化学成分录入界面,并展示数据库内容,删除选中的数据。具体效果如下: 一、前端Leptos程序 前端程序主…...
MySQL 5.7.43 二进制安装指南:从零开始的高效快速实现安装部署
目录 引言:为什么选择二进制安装? 1 环境准备 1.1 基础环境检查 1.2 系统安全设置 2 系统优化配置 2.1 磁盘调度策略 2.2 系统资源限制 3 mariadb删除 4 依赖包安装 5 MySQL二进制安装包下载 6 MySQL安装部署 6.1 解压安装包 6.2 创建用户以…...
使用U盘安装 ubuntu 系统
1. 准备U 盘制作镜像 1.1 下载 ubuntu iso https://ubuntu.com/download/ 这里有多个版本以供下载,本文选择桌面版。 1.2 下载rufus https://rufus.ie/downloads/ 1.3 以管理员身份运行 rufus 设备选择你用来制作启动项的U盘,不能选错了;点…...
【家政平台开发(42)】筑牢家政平台安全防线:安全测试与漏洞修复指南
本【家政平台开发】专栏聚焦家政平台从 0 到 1 的全流程打造。从前期需求分析,剖析家政行业现状、挖掘用户需求与梳理功能要点,到系统设计阶段的架构选型、数据库构建,再到开发阶段各模块逐一实现。涵盖移动与 PC 端设计、接口开发及性能优化,测试阶段多维度保障平台质量,…...
JavaWeb-04-Web后端基础(SpringBootWeb、HTTP协议、分层解耦、IOC和DI)
目录 一、SpringBootWeb入门 1.1 概述 1.2 入门程序 1.2.1 需求 1.2.2 开发步骤 1.3 入门解析 二、HTTP协议 2.1 HTTP概述 2.1.1 介绍 2.1.2 特点 2.2 HTTP请求协议 2.2.1 介绍 2.2.2 获取请求数据 2.3 HTTP响应协议 2.3.1 格式介绍 2.3.2 响应状态码 2.3…...
随笔 20250413 Elasticsearch 的 term 查询
你这个问题非常经典,来自于 Elasticsearch 的 term 查询是 ✅精确匹配(case-sensitive,大小写敏感)! 🧨 为什么查不到 "World"? 你的查询语句是: GET /movie/_search {&…...
zk(Zookeeper)实现分布式锁
Zookeeper实现分布式锁 1,zk中锁的种类: 读锁:大家都可以读,要想上读锁的前提:之前的锁没有写锁 写锁:只有得到写锁的才能写。要想上写锁的前提是:之前没有任何锁 2,zk如何上读锁 创…...
操作系统简要概述
操作系统是计算机系统的核心软件,它管理和控制计算机硬件与软件资源,为用户提供方便、高效、安全的使用环境。以下是关于操作系统的详细介绍: 一、定义 操作系统(Operating System,简称 OS)是计算机硬件与…...
开漏模式的触发条件和工作状态
MOS管的漏-栅-源三极 漏极开路--开漏 电路整体概述 这是开漏(Open - Drain)电路结构,核心由输出控制模块和一对互补的MOS管(P - MOS和N - MOS)组成。开漏电路的特点是MOS管漏极开路,这种结构常用于需要实现…...
【Java学习笔记】Java第一课,梦开始的地方!!!
目录 1. 基本内容介绍和软件安装 2. 快速入门之第一个程序 hello world 3. 学习方法 基本介绍和软件安装 一、 Java 岗位与应用场景 说明:java 基础也称javaSE 岗位 1. javaEE 软件工程师 电商领域 团购 众筹 sns(社交网络) 教育 金…...
共享内存技术
一、共享内存 共享内存是一种高效的 进程间通信(IPC) 机制,允许多个进程直接访问同一块物理内存区域,无需通过内核缓冲区或文件进行数据拷贝。它通常用于需要 低延迟、高吞吐量 的数据交换场景(如实时系统、高频交易、…...
Lc 大数运算--快速幂 | 统计好数字的数目
快速幂算法是一种高效计算大数幂运算的方法,能将时间复杂度从传统算法的O(n)降低到O(log n)。它的核心思想是 分解指数分治思想,类似生活中的「拆快递」—— 把大包裹拆成小份,分批处理更高效。 一、生活示例:存钱罐的复利计算 假…...
Linux内存管理架构(2)
4.虚拟地址空间布局 4.1虚拟地址空间划分 对于64位处理器,目前不支持完全的64位虚拟地址 1.ARM64内核/用户虚拟地址划分 1. 虚拟地址的最大宽度 最大宽度:虚拟地址的最大宽度是48位。 内核虚拟地址: 在64位地址空间的顶部。高16位全是1。范围…...
图论基础理论
在我看来,想要掌握图的基础应用,仅需要三步走。 什么是图(基本概念)、图的构造(打地基)、图的遍历方式(应用的基础) 只要能OK的掌握这三步、就算图论入门了!࿰…...
最大子序和问题——动态规划/贪心算法解决
目录 一:问题描述 二:解决思路1——动态规划思想 三:C 语言代码实现 四:复杂度分析 五:解决思路2——贪心算法思想 六:具体步骤 七: C语言代码实现 八:复杂度分析 一:问题描述 …...
车载以太网-SOMEIP
文章目录 基本概念SOME/IP的起源与核心定位核心定位设计目标协议栈架构与OSI模型映射报文结构与数据序列化SOME/IP的核心通信机制通信模式分类服务发现协议(SOME/IP-SD)服务发现流程服务质量(QoS)管理SOME/IP在智能汽车中的典型应用SOME/IP测试与验证体系SOME/IP测试环境构…...
DrissionPage详细教程
1. 基本概述 DrissionPage 是一个基于 python 的网页自动化工具。它既能控制浏览器,也能像requests一样收发数据包,更重要的是还能把两者合二为一。因此,简单来说DrissionPage可兼顾浏览器自动化的便利性和 requests 的高效率。 DrissionPa…...
6.1 GitHub亿级数据采集实战:双通道架构+三级容灾设计,破解API限制与反爬难题
GitHub 项目数据获取功能设计与实现 关键词:GitHub API 集成、网页爬虫开发、数据存储设计、定时任务调度、异常处理机制 1. 数据获取架构设计 采用双通道数据采集策略,同时使用 GitHub 官方 API 和网页爬虫技术确保数据完整性: #mermaid-svg-XUg7xhHrzFAozG4J {font-fami…...
LabVIEW 控制电机需注意的关键问题
在自动化控制系统中,LabVIEW 作为图形化编程平台,因其高度可视化、易于集成硬件等优势,被广泛应用于电机控制场景。然而,要实现稳定、精确、高效的电机控制,仅有软件并不足够,还需结合硬件选型、控制逻辑设…...
Linux系统远程操作和程序编译
目录 一、Linux远程终端登录、图形桌面访问、 X图形窗口访问和FTP文件传输操作 1.1 桥接模式 1.2 putty远程登录Ubuntu 1.3 win10远程登录并上传下载文件 1.4 X server仿真软件安装 1.5 树莓派在putty上的远程登录 1.6 使用ftp远程登录并实现文件上传下载 1.7 Linux下的…...
Mac配置开发环境
博主是一名Python后端开发,有时候环境太多 需要配置太多,故做此文章 环境Macbook ,请注意自己的是ARM 还是x86 结构 Vscode/Cursor配置Python debug 配置Debug launch.json {"version": "0.2.0","configuratio…...
LabVIEW配电器自动测试系统
随着航天技术的迅猛发展,航天器供配电系统的结构越来越复杂,对配电器的功能完整性、稳定性和可靠性提出了更高要求。传统人工测试方式难以满足高效率、高精度、可重复的测试需求。本项目开发了一套基于LabVIEW平台的宇航配电器自动测试系统,融…...
生成与强化学习:赋予VLA系统物理行动能力
引言:从“理解世界”到“改变世界” 当机器能够“看懂”图像、“听懂”指令时,一个更根本的挑战浮现:如何让它们像人类一样,将认知转化为精准的物理动作?无论是机械臂抓取杯子,还是自动驾驶汽车紧急避障&a…...
基于Springboot+Mysql的闲一品(含LW+PPT+源码+系统演示视频+安装说明)
系统功能 管理员功能:首页、个人中心、用户管理、零食分类管理、零食信息管理、订单评价管理、系统管理、订单管理。用户功能:首页、个人中心、订单评价管理、我的收藏管理、订单管理。前台首页功能:首页、零食信息、零食资讯、个人中心、后…...
jupyter4.4安装使用
一、chrome谷歌浏览器 1. 安装 1.1 下载地址: 下载地址: https://www.google.cn/intl/zh-CN_ALL/chrome/fallback/ 2 插件markdown-viewer 2.1 下载地址: 下载地址:https://github.com/simov/markdown-viewer/releases 2.2…...
Linux虚拟内存详解
引言 虚拟内存是现代操作系统中的核心概念之一,它为进程提供了一个连续的、独立的地址空间,有效解决了物理内存限制问题,并大大简化了程序开发和执行。本文将深入探讨Linux系统中虚拟内存的工作原理、实现机制以及相关的内存管理技术&#x…...
数据库安装(基于Linux下centos7)(保姆级教程)
前言:笔者有段时间没写博客了,今天笔者要分享新的知识了,那就是数据库,笔者会通过博客系统的且通俗易懂的分享数据库知识,对于想要学习数据库和学习过数据库的老铁复习都是非常有用的,绝对干货满满,那么今天…...
【自动驾驶 机器人】速度规划 |梯形/S型速度曲线
参考文章: (1)【自动驾驶】运动规划丨速度规划丨T型/S型速度曲线 (2)一文教你快速搞懂速度曲线规划之S形曲线(超详细图文推导附件代码) 1 梯形速度曲线 如下图所示梯形速度/加速度/加加速度曲…...
Qt C++内存泄漏排查方法
在Qt C++中排查内存泄漏可以按照以下步骤进行,结合工具使用和代码审查: 1. 使用内存检测工具 Valgrind (Linux/macOS) 安装Valgrind:sudo apt-get install valgrind运行程序并检测内存泄漏:valgrind --leak-check=full ./your_qt_app分析输出结果,定位未释放的内存块。Dr…...
[redis进阶一]redis的持久化(2)AOF篇章
目录 一 为什么有了RDB持久化机制还要有AOF呢 板书介绍具体原因: 编辑二 详细讲解AOF机制 (1)AOF的基本使用 1)板书如下 2)开启AOF机制: 3) AOF工作流程 (2)AOF是否会影响到redis性能 编辑 (3)AOF缓冲区刷新策略 (4)AOF的重写机制 板书如下: 为什么要有这个重写机…...
聊天室项目day4(redis实现验证码期限,实现redis连接池)
1.redis连接池操作和之前所学过的io_context连接池原理一样这里不多赘述,也是创建多个连接,使用时按顺序取出来。 2.知识补充redisConnect()函数建立与 Redis 服务器的非阻塞网络连接,成功返回 redisContext*(连接上下文指针&…...
Redis之分布式锁
面试切入点 锁的分类 单机版同一个JVM虚拟机内,synchronized或者Lock接口分布式多个不同JVM虚拟机,单机的线程锁不再起作用,资源类在不同的服务器之间共享了 一个靠谱分布式锁需要具备的条件与刚需 独占性:onlyOneÿ…...