AutoCV第二课:Python基础

目录

  • Python基础
    • 前言
    • 1.流程控制
      • 1.1 条件语句
      • 1.2 循环语句
        • 1.2.1 while循环语句
        • 1.2.2 for循环语句
      • 1.3 作业
      • 1.4 拓展-try except语法
    • 2.函数
      • 2.1 函数定义
      • 2.2 函数的参数
        • 2.2.1 位置参数
        • 2.2.2 命名参数
        • 2.2.3 默认参数
        • 2.2.4 可变参数
        • 2.2.5 参数展开
      • 2.3 递归函数
        • 2.3.1 递归函数定义
        • 2.3.2 斐波拉契数列实现
      • 2.4 作业
      • 2.5 匿名函数
        • 2.5.1 定义
        • 2.5.2 拓展-sorted()函数
    • 总结

Python基础

前言

手写AI推出的全新保姆级从零手写自动驾驶CV课程,链接。记录下个人学习笔记,仅供自己参考。

本次课程为第二课,主要讲解Python中的流程控制(条件和循环语句)以及函数(定义和函数参数)

课程大纲可看下面的思维导图。

在这里插入图片描述

1.流程控制

内容:认识控制流程,判断、循环

1.1 条件语句

Python中的条件语句包括if、elif和else关键字if语句的基本语法如下:

if condition1:statement
elif condition2:statement
elif condition3:statement
else:statement

1.2 循环语句

1.2.1 while循环语句

Python中的while循环语句用于重复执行一段代码,直到条件变为False为止,while的基本语法如下:

while condition:statement

while循环语句可以和break语句一起使用来提前结束循环

1.2.2 for循环语句

Python中的for循环语句可以对序列和可迭代对象进行遍历,语法格式如下:

for variable in Iterator:statement

其中,Iterator指的是支持迭代操作的对象,包括字符串、列表、元组、集合、字典等。variable是在每次循环中接收可迭代对象中的元素。

示例代码如下,遍历整数序列求和:

sum = 0
for i in range(1, 11):sum += i
print("1到10的和为:", sum)

此外,for循环语句还支持breakcontinue关键字,同于控制循环的执行流程。break用于终止整个循环,continue用于跳过当前循环,进入下一次循环。

for还可以和列表进行其它的配合,如

  1. list = [i for i in iterator]

这种方式使用了列表推导式,通过对iterator进行遍历,生成一个新的列表

  1. list = [i for i in range(0, 5, 2) if i != 4]

这种方式是在列表推导式的基础上,添加了一个条件表达式

1.3 作业

作业4:写一个计算器,输入表达式,输出计算结果
运行效果如下:

在这里插入图片描述

示例代码如下:

# 两数的四则运算
while True:# 获取输入表达式expression = input("mycalc>")# 获取+、-、*、/operators = '+-*/'index = [i for i in range(len(expression)) if expression[i] in operators]# 如果存在四则运算符if index:num1 = int(expression[:index[0]])num2 = int(expression[index[0]+1:])if expression[index[0]] == "+":print(num1+num2)elif expression[index[0]] == "-":print(num1-num2)elif expression[index[0]] == "*":print(num1*num2)elif expression[index[0]] == "/" and num2 != 0:print(num1/num2)else:print("Error, divisor cannot be zero! Please try again")

优化:使用函数封装以及try except优化,示例代码如下(Suggestion from chatGPT)

def add(num1, num2):return num1 + num2def subtract(num1, num2):return num1 - num2def multiply(num1, num2):return num1 * num2def divide(num1, num2):if num2 == 0:raise ValueError("Error, divisor cannot be zero!")return num1 / num2if __name__ == "__main__":while True:# 获取表达式expression = input("mycala>")# 获取+、-、*、/operators = '+-*/'index = [i for i in range(len(expression)) if expression[i] in operators]# 如果存在四则运算符if index:num1 = int(expression[:index[0]])num2 = int(expression[index[0]+1:])operator = expression[index[0]]# 根据不同的运算符调用不同的函数进行计算try:if operator == "+":result = add(num1, num2)elif operator == "-":result = subtract(num1, num2)elif operator == "*":result = multiply(num1, num2)elif operator == "/":result = divide(num1, num2)print(result)except ValueError as e:print(e)

继续优化:

  1. 输入的表达式只能包含两个操作数,不能进行多个数的计算
  2. 多个表达式意味着需要考虑*和/的优先级,复杂度提高

优化的示例代码如下:(from chatGPT)

while True:# 获取表达式并去除空格expression = input("mycalc>")# 使用eval函数计算表达式try:result = eval(expression)print(result)except ZeroDivisionError:print("Error, divisor cannot be zero! Please try again")except:print("Invalid expression! Please try again")

说明

  • eval函数可以将包含数学运算符的字符串转换为实际的数学运算结果
  • try except是Python中异常处理的语法结构,用于处理可能会出现的异常代码块。

1.4 拓展-try except语法

try except是Python中异常处理的语法结构,用于处理可能会出现的异常代码块。具体来说try语句包含了要尝试执行的代码块,而except语句包含了在出现异常时要执行的代码块。如果在try代码块中出现了异常,那么程序会跳转到except代码块,并执行其中的代码。

try语句的基本结构如下:

try:# 尝试执行的代码块
except:# 发生异常时要执行的代码块

其中except可以指定不同的异常类型,以便更精确地处理异常。例如,下面代码处理了除以零异常:

try:x = 1 / 0
except ZeroDivisionError:print("除以零错误!")

除了指定具体的异常类型之外,也可以使用except语句来捕获所以异常,例如:

try:# 尝试执行的代码块
except Exception as e:# 发生异常时要执行的代码块

except中,可以使用as关键字来将异常对象赋值给一个变量,以便更详细地了解异常信息。

此外,还可以使用else来指定在没有发生异常时要执行的代码块,例如:

try:# 尝试执行的代码块
except:# 发生异常时要执行的代码块
else:# 没有发生异常时要执行的代码块

最后,还可以使用finally子句来指定不管是否发生异常都要执行的代码块,例如:

try:# 尝试执行的代码块
except:# 发生异常时要执行的代码块
finally:# 不管是否发生异常都要执行的代码块

这在需要释放资源或清理状态时非常有用

2.函数

内容:认识函数的定义、位置参数和命名参数、可变参数、参数的展开(from chatGPT)

2.1 函数定义

在Python中,函数的定义需要使用def关键字,基本的语法格式如下:

def function_name(parameter_list):"""Docstring"""# Function Bodyreturn expression

其中:

  • function_name是函数的名称,必须符合Python的标识规则,通常使用小写字母和下划线组成,不推荐使用与Python内置函数和关键字相同的名称
  • parameter_list是函数的参数列表,可以有零个或多个参数,多个参数之间用逗号分隔。参数可以是位置参数(必选参数)或关键字参数(可选参数)
  • Docstring是函数的文档字符串,用于描述函数的功能和使用方法,通常使用三引号"""包围
  • return语句用于返回函数的执行结果

示例如下:

def sum_numbers(*numbers):"""计算任意数量的数值的和"""sum = 0for n in numbers:sum += nreturn sum# 调用函数
result = sum_numbers(1, 2, 3, 4, 5)
print(result)   # 15

2.2 函数的参数

在Python中,函数参数可分为四种类型:位置参数、命名参数、默认参数和可变参数

2.2.1 位置参数

位置参数是指函数调用时按照定义的位置传递的参数。例如:

def func(a, b):print(a, b)func(1, 2)  # 输出: 1 2

在这个例子中,参数1被传递给了a,参数2被传递给了b。由于参数的位置是固定的,所以这些参数被称为位置参数。

2.2.2 命名参数

在Python中,还可以使用命名参数(关键字参数)指定参数的值,而不需要按照函数定义时参数的位置进行传递,例如:

def func(a, b):print(a, b)func(b=2, a=1)  # 输出: 1 2

在这个例子中,我们通过b=2a=1来指定参数的值。因为参数的值是根据名称指定的,所以这些参数被称为命名参数。

2.2.3 默认参数

默认参数是指在定义函数时为参数提供默认值,如果在调用函数时没有指定参数的值,就使用默认值。例如:

def func(a=1, b=2):print(a, b)func()         # 输出: 1 2
func(3)        # 输出: 3 2
func(b=5)      # 输出: 1 5
func(6, b=7)   # 输出: 6 7

在这个例子中,参数a的默认值为1,参数b的默认值为2。如果没有指定参数的值,则使用默认值。如果指定了某些参数的值,则只有指定的参数会使用这些值,而其它参数仍然使用默认值。

2.2.4 可变参数

可变参数是指能够接受不定数量的参数的函数。在Python中,有两种类型的可变参数:*args**kwargs

*args:接受不定数量的位置参数,这些参数被组合成一个元组。例如:

def func(*args):print(args)func(1, 2)   # 输出: (1, 2)

在这个例子中,参数1,2被组合成了一个元组,并作为参数传递给函数func()

**kwargs:接受不定数量的关键字参数,这些参数被组合成一个字典。例如:

def func(**kwargs):print(kwargs)func(a=1, b=2)  # 输出: {'a': 1, 'b': 2}

在这个例子中,参数a,b被组合成了一个字典,并作为参数传递给函数func()

2.2.5 参数展开

在Python中,使用展开操作符***可以将可迭代对象(例如列表、元组、字典等)中的元素展开成函数的参数,用于函数调用。

*可以将一个可迭代对象中的元素展开为位置参数,传递给函数。例如:

def my_func(a, b):print(a, b)my_list = [1, 2]
my_func(*my_list)  # 输出:1 2

**可以将一个字典中的键值对展开成关键字参数,传递给函数。例如:

def my_func(a, b):print(a, b)my_dict = {'a': 1, 'b': 2}
my_func(**my_dict)  # 输出:1 2

***可以混合使用将位置参数和关键字参数同时展开。例如:

def my_func(a, b, c):print(a, b, c)my_list = [1, 2]
my_dict = {'c': 3}
my_func(*my_list, **my_dict)  # 输出:1 2 3

2.3 递归函数

2.3.1 递归函数定义

Python中的递归函数指在函数内部调用自身的函数。递归函数通常需要满足两个条件:基本情况和递归情况。基本情况指满足某个条件时直接返回结果,递归情况则是指在函数内部调用自身,通常是将问题规模缩小到一个更小的子问题。

例如,下面的代码时一个求阶乘的递归函数:

def factorial(n):if n == 1:return 1else:return n * factorial(n-1)

在上述代码中,当n等于1时,直接返回1,这就是基本情况。递归情况则是将问题规模缩小到n-1的阶乘,这里通过factorial(n-1)实现。递归函数的执行过程是将问题不断地拆分成更小的子问题,直到最终的基本情况被满足,然后将所有子问题结果合并起来得到最终的结果。

2.3.2 斐波拉契数列实现

定义:斐波拉契数列是一个非常经典的数列,它的前两项为0和1,从第三项开始,每一项都是前两项的和,即0,1,1,2,3,5,8,13,…

实现:斐波拉契数列的实现包含循环和递归两种方法

实现1.循环方法

def fibonacci1(n):if n<=1:return nelse:fib_list = [0, 1]for i in range(2, n+1):fib_list.append(fib_list[-1] + fib_list[-2])return fib_list

实现2.递归方法

def fibonacci(n):if n == 1:return [0, 1]else:fib_list = fibonacci(n-1)fib_list.append(fib_list[-1] + fib_list[-2])return fib_list

递归函数是指在函数中调用函数本身的一种技术。代码简单但看得有点迷糊,自己画了个简单图示并理解了下(不知道理解是否正确😂)

递归就是一个套娃的过程,为了便于理解画了个图示,假设此时n=5,不同的颜色来表示不同的flib函数,

  1. n=5时,调用灰色的fib函数,程序运行到第5行进入新的fib函数(套的第一层)
  2. 新的fib函数即n=4.,也就是蓝色的fib函数,同理运行到第5行又进入新的fib函数(套的第二层)
  3. 继续上述过程,n=3,也就是绿色的fib函数,运行到第5行跳转(套的第三层)
  4. 继续,n=2,也就是橙色的fib函数,运行到第5行跳转(套的第四层)
  5. 继续,n=1,也就是黄色的fib函数,此时满足条件n==1,返回[0,1]的一个列表
  6. 开始往回走了,n=2,此时fib_list=[0,1],运行到第六行fib_list=[0,1,1],将结果返回到上一层(脱的第一层)
  7. n=3,此时fib_list=[0,1,1],运行到第六行fib_list=[0,1,1,2],继续将结果返回到上一层(脱的第二层)
  8. n=4,此时fib_list=[0,1,1,2],运行到第六行fib_list=[0,1,1,2,3],继续返回给上一层(脱的第三层)
  9. n=5,此时fib_list=[0,1,1,2,3],运行到第六行fib_list=[0,1,1,2,3,5],将最终的结果返回(脱的第四层)

在这里插入图片描述

递归图示

2.4 作业

作业5:定义一个函数extract(text, begin_token, end_token),返回text中,以begin_token开始end_token结束的中间内容

示例代码如下:

def extract(text, begin_token, end_token):begin_index = text.find(begin_token)end_index = text.find(end_token)return text[begin_index+len(begin_token):end_index]print(extract("爱听歌的周同学呀", "爱听歌的", "呀"))

运行效果如下:

在这里插入图片描述

存在的问题:(from chatGPT)

    1. 当begin_token或end_token不在text中时,会返回错误的结果
    1. begin_token和end_token必须按照顺序一次出现在text中,否则无法正确提取中间内容。

优化

def extract(text, begin_token, end_token):begin_index = text.find(begin_token)if begin_index == -1:raise ValueError("begin_token not found")end_index = text.find(end_token, begin_index+len(begin_token))if end_index == -1:raise ValueError("end_token not found")return text[begin_index+len(begin_token):end_index]print(extract("我爱Python,Python是一门很有用的语言", "Python", "语言"))

2.5 匿名函数

2.5.1 定义

Python中的匿名函数又称为lambda函数,是一种不需要定义函数名的函数。lambda函数的语法如下:

lambda arguments: expression

其中arguments表示函数的参数,可以有多个,使用逗号分隔。expression表示函数的表达式,可以是任何有效的表达式。lambda函数的返回值是一个函数对象。

lambda函数的简单示例如下:

sum = lambda x, y: x + y
print(sum(3, 5))	# 输出:8

在这个例子中,我们创建了一个lambda函数,将它赋值给了变量sum。这个函数接受两个参数x和y,共返回它们的和。我们通过调用sum(3,5)来调用这个函数,并输出结果8。

lambda函数通常用于需要简单函数的场景,可以简化代码,并提高代码的可读性。例如,使用lambda函数对列表进行排序:

data = [('apple', 3), ('banana', 2), ('orange', 4)]
sorted_data = sorted(data, key=lambda x: x[1])
print(sorted_data)	# 输出:[('banana', 2), ('apple', 3), ('orange', 4)]

在这个例子中,我们使用了lambda函数作为sorted()函数的key参数,以元组的第二个元素作为排序的关键字。

不由的想起检测器的NMS算法之前需要将boxes按照置信度的大小进行排序,其代码如下:

...# boxes-->[1,25200,85]  box->[left, top, right, bottom, confidence, img_id, label]
boxes = sorted(boxes.tolist(), key=lamda x:x[4], reverse=True)return NMS(boxes)
...

2.5.2 拓展-sorted()函数

在Python中,Sorted()函数用于对可迭代对象进行排序,返回一个新的已排序的列表,而不改变原始对象。

sorted()函数有以下几个参数:

  • iterable:必选参数,表示要排序的可迭代对象,可以是列表、元组、集合、字典等
  • key:可选参数,表示用于排序的关键字函数,用于比较两个元素的大小关系。默认值为None,表示使用元素本身的值进行比较。
  • reverse:可选参数,表示是否降序排列。默认值为False,表示升序排列。

sorted()函数使用示例如下:

# 对列表进行升序排列
nums = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5]
sorted_nums = sorted(nums)
print(sorted_nums)  # [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9]# 对字典按值进行升序排列
d = {'apple': 3, 'banana': 2, 'orange': 4}
sorted_d = sorted(d.items(), key=lambda x: x[1])
print(sorted_d)  # [('banana', 2), ('apple', 3), ('orange', 4)]

上面的代码中,第一个示例是对列表进行排序,不需要使用关键字函数key。第二个示例是对字典按值进行排序,使用了关键字函数key,并且使用匿名函数lambda来定义比较元素大小的规则,即按照每个元素的第二个值进行升序排列。其中d.items()方法将字典转换为元组列表。

总结

本次课程内容方面主要学习了Python中的流程控制和函数,流程控制方面掌握了for与列表构成带条件的列表推导式,同时回顾了Python中异常处理的语法结构try excepy。函数方面掌握了各种传递函数参数的方法,以及两种特殊的函数:递归函数和匿名函数。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/46905.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu20.04服务器接收SYN,不返回SYN+ACK

情况 Ubuntu20.04 live 服务器启动了一个Nginx服务&#xff0c;服务使用80端口&#xff0c;服务器有2个网卡。经过公司H3C路由器NAT转发&#xff0c;将内部服务器的80端口映射到公网5088端口。通过内网的主机可以服务Nginx服务&#xff0c;通过公网IP5088端口&#xff0c;无法…

IP编址(包括网络地址和广播地址)

1.总述 IP地址使用32位二进数表示&#xff0c;每一个主机或路由器的接口都有全局唯一的IP地址&#xff08;NAT是个例外&#xff09;&#xff0c;它由网络号(NetID)和主机号(HostID)组成&#xff0c;它可以分为五类&#xff0c;如下&#xff1a; 2.地址划分 1&#xff09;A…

怎样解决ip访问受限问题

现在是互联网时代。一些网络工作者需要收集一些网站的数据&#xff0c;收集数据需要频繁访问网站。为了有效控制网站流量&#xff0c;保证用户访问速度&#xff0c;一些目标网站会限制单个IP访问请求次数。对于爬虫工作者来说&#xff0c;目标网站限制访问的机制让他们头疼。那…

vcenter服务器修改ip,vcenter服务器默认ip地址

vcenter服务器默认ip地址 内容精选 换一换 安全组类似防火墙功能,是一个逻辑上的分组,用于设置网络访问控制。用户可以在安全组中定义各种访问规则,当弹性云服务器加入该安全组后,即受到这些访问规则的保护。入方向:入方向规则放通入方向网络流量,指从外部访问安全组规则…

没有计算机网络地址怎么办,教大家电脑没有ip地址mac地址怎么办

近日有关于电脑没有ip地址mac地址怎么办的问题受到了很多网友们的关注,大多数网友都想要知道电脑没有ip地址mac地址怎么办的具体情况,那么关于到电脑没有ip地址mac地址怎么办的相关信息,小编也是在网上进行了一系列的信息,那么接下来就由小编来给大家分享下小编所收集到与电…

什么是IP地址

一、IP地址概念 IP地址是一个32位的二进制数&#xff0c;它由网络ID和主机ID两部份组成&#xff0c;用来在网络中唯一的标识的一台计算机。网络ID用来标识计算机所处的网段&#xff1b;主 机ID用来标识计算机在网段中的位置。IP地址通常用4组3位十进制数表示&#xff0c;中间用…

IP地址的规划和设计方法(一)

一&#xff0c;IP地址的概念和划分地址新技术的研究 (1)标准分类的IP地址 第一阶段是在IPv4协议制定的初期&#xff0c;时间大致在1981年左右。那时候网络的规模比较小&#xff0c;用户一般是通过终端&#xff0c; 经过大型计算机或中小型计算机接入ARPANET。 IP地址是由网络号…

IP地址划分和子网

本文主要介绍IP地址划分&#xff0c;子网&#xff0c;子网掩码相关知识。 IP地址划分历史 根据IP地址的研究和发展&#xff0c;暂时分为4个阶段&#xff0c;重要是前两个阶段。 标准分类的IP地址 最开始接入网络的计算机比较少&#xff0c;IP地址由网络号和主机号构成&#x…

计算机三级考点8:IP地址分类。

IP地址分类。 1.标准分类的IP地址。 常用的A类&#xff0c;B类&#xff0c;C类采用包括“网络号-主机号”的两极的层级结构。 IP地址::{<网络号>,<主机号>}] IPv4的地址长度是32bit&#xff0c;用点分十进制表示&#xff0c;如x.x.x.x的格式。其中每个x为8bit&a…

cloudflare边缘IP受限报错1034解决方案

1034报错原因 cloudflare官方说明写的很清楚&#xff0c;将域指向 1.1.1.1 的客户现在会遇到 1034 错误。这是因为 Cloudflare 系统采取了新的边缘验证检查措施&#xff0c;目的是防止配置错误和/或潜在的滥用。 解决方案 官方说明&#xff1a;确保 DNS 记录指向您控制的 IP 地…

特殊ip地址——受限广播地址

在 IPv4 中&#xff0c;一个受限广播地址是指一个用于发送广播信息的特殊地址&#xff0c;它的范围是限定在一个子网内的。这种地址用来发送信息给与发送者在同一子网内的所有计算机。受限广播地址的形式通常是最后一个子网地址加上 255&#xff0c;例如&#xff0c;如果子网地…

asp.net医院信息管理系统

医院信息管理系统是一个专门为医院服务的系统&#xff0c;严格的按照医院的就诊流程进行的开发&#xff0c;同时为了能够让工作人员更方便的上手系统&#xff0c;系统的开发遵循了简单&#xff0c;大方的开发原则。 首先病人来了以后有挂号人员根据病人的实际情况进行挂号&…

500强企业常用的高效工作方法

文章目录 前言一、500强企业常用的高效工作方法二、1.30秒法则2.PDCA3.5W1H4.ECRS5.SMART6.SWOT分析法7.4M1E法8.28原则9.ASK模型10.5s管理11.海因里希法则12.鱼骨图分析法13.DISC模型14.时间四项法则15.有效沟通的7C原则16.高效人士七个习惯 前言 带着“如何在最短时间内做最…

计算机病毒常见病状,有哪些常见的计算机病毒症状

计算机中了病毒有什么症状呢?通常情况下&#xff0c;当计算中病毒后&#xff0c;在电脑操作者看来并无明显的特征&#xff0c;但是我们仍然可以通过一些细节问题来判断电脑是否已中病毒。下面就让学习啦小编给大家说说常见的计算机病毒症状有哪些吧。 常见的计算机病毒症状 文…

backtrader量化回测----基础使用1,附完整代码

今天我们体测完1000米感觉人都要废了&#xff0c;目前在学习天勤量化&#xff0c;但是我还是打算仔细将这个量化框架介绍完&#xff0c;我们开始下面介绍来自官网&#xff0c;因为有时候官网打不开&#xff0c;我将仔细介绍&#xff0c;我们开始。 需要程序关注微信公众号&…

神经网络量化之 Ristretto、增量量化INQ、IAO代码实战分析

神经网络量化之 Ristretto、增量量化INQ、IAO代码实战分析 博文末尾支持二维码赞赏哦 _ 1. Ristretto 固定点浮点数量化 详细介绍 量化逼近方案 Ristretto允许以三种不同的量化策略来逼近卷积神经网络&#xff1a; 1、动态固定点&#xff1a;修改的定点格式&#xff0c; D…

自己做量化交易软件(42)小白量化实战15--自编股票软件公式历史与聚宽量化平台仿大智慧指标回测设计

自己做量化交易软件(42)小白量化实战15–自编股票软件公式历史与聚宽量化平台仿大智慧指标回测设计 在1997年以前&#xff0c;市面上已经出现了很多股票分析软件。大多数软件都集成好了一些常用指标&#xff0c;例如钱龙股票分析系统&#xff0c;海融股票分 析系统&#xff0c…

量化交易 第六课 策略评估指标计算

第六课 策略评估指标计算 概述获取取票数据回测收益率回测年华收益率最大回撤夏普比率 概述 我们在创建策略的过程中, 需要通过不同的评估指标来验证策略的有效性. 这些指标可以帮助我们调整策略, 得到更好的结果. 常见的策略评估指标有: 回测收益率回测年化收益率最大回撤夏…

自己做量化交易软件(3)通通量化分析框架构成1

自己做量化交易软件(3)通通量化分析框架构成1 通通股票量化分析框架采用模块化设计&#xff0c;每个模块存放在不同的py文件中。 通通股票量化分析框架下载&#xff1a; https://download.csdn.net/download/hepu8/10668509 运行python环境,可以在我的网盘下载绿色python软…

股票量化分析工具V2.0版-视频更新完毕!代码已上传!

视频课程《理性投资&#xff01;2天入门量化思维炒股&#xff01;定制自己的股票分析工具》Day1录播内容已全部上线。 已经购买的读者们速去学习&#xff01;&#xff01;&#xff01; ----点击【阅读原文】跳转 升级的V2.0回测工具的代码已经上传课件&#xff0c;同时也上传了…