【数学建模学习手册】python基本入门使用

news/2024/9/17 4:52:20/ 标签: 数学建模, 学习, python

本专栏内容为:数学建模原理 记录学习数学建模

💓博主csdn个人主页:小小unicorn
⏩专栏分类:数学建模
🚚代码仓库:小小unicorn的代码仓库🚚
🌹🌹🌹关注我带你学习编程知识

目录

  • numpy库
    • 导入
    • 数组创建
      • 示例1:
      • 示例2:
    • 数组元素索引:
      • 示例:
    • 矩阵运算与线性代数
    • 求解线性方程组的唯一解
      • 例1:求解线性方程组:
    • 求超定方程组的最小二乘解
      • 例2:求解线性方程组:
        • 第一种:
        • 第二种:
        • 两种方法的比较:
      • 什么是超定方程?
    • 求矩阵的特征值特征向量:
  • Pandas库
    • 生成二维数组:
    • 读写文件
    • 数据预处理:
  • SciPy库
    • 求解非线性方程组
    • 积分:
    • 最小二乘解
    • 求矩阵最大模特征值与特征向量
  • SymPy库
    • 例1:求符号解
    • 例2:求符号解
    • 例3:求矩阵的特征值与特征向量(符号解)
  • Matplotlib库
    • 子图:
    • 三维绘图
      • 例1:三维曲线

numpy库

导入

python">import numpy as 

数组创建

在这里插入图片描述

示例1:

python">import numpy as np
a1 = np.array([1, 2, 3, 4])   #生成整型数组
a2 = a1.astype(float)
a3 = np.array([1, 2, 3, 4], dtype=float)   #浮点数
print(a1.dtype); print(a2.dtype); print(a3.dtype)
b = np.array([[1, 2, 3], [4, 5, 6]])
c = np.arange(1,5)        #生成数组[1, 2, 3, 4]
d = np.linspace(1, 4, 4)  #生成数组[1, 2, 3, 4]
e = np.logspace(1, 3, 3, base=2)  #生成数组[2, 4, 8]
print(b)
print(c)
print(d)
print(e)

示例2:

python">import numpy as np
a = np.ones(4, dtype=int)     #输出[1, 1, 1, 1]
b = np.ones((4,), dtype=int)  #同a
c= np.ones((4,1))             #输出4行1列的数组
d = np.zeros(4)               #输出[0, 0, 0, 0]
e = np.empty(3)               #生成3个元素的空数组行向量
f = np.eye(3)                 #生成3阶单位阵
g = np.eye(3, k=1)  #生成第k对角线的元素为1,其他元素为0的3阶方阵
h = np.zeros_like(a)          #生成与a同维数的全0数组

数组元素索引:

在这里插入图片描述

示例:

python">import numpy as np
a = np.arange(16).reshape(4,4)  #生成4行4列的数组
b = a[1][2]   #输出6
c = a[1, 2]   #同b
d = a[1:2, 2:3]  #输出[[6]]
x = np.array([0, 1, 2, 1])
print(a[x==1])  #输出a的第2、4行元素

在这里插入图片描述

矩阵运算与线性代数

线性代数只要使用numpy.linalg模块,其常用函数如下:
在这里插入图片描述

求解线性方程组的唯一解

例1:求解线性方程组:

在这里插入图片描述
代码:

python">import numpy as np
a = np.array([[3, 1], [1, 2]])
b = np.array([9, 8])
x1 = np.linalg.inv(a) @ b  #第一种解法
#上面语句中@表示矩阵乘法
x2 = np.linalg.solve(a, b) #第二种解法
print(x1); print(x2)

结果:
在这里插入图片描述

求超定方程组的最小二乘解

例2:求解线性方程组:

在这里插入图片描述
代码:

第一种:
python">import numpy as np
a = np.array([[3, 1], [1, 2], [1, 1]])
b = np.array([9, 8, 6])
#a*b
x = np.linalg.pinv(a) @ b  
print("求得的最小二乘解为:")
print(np.round(x, 4))
第二种:

使用 lstsq 求解最小二乘问题:

  • a: 系数矩阵。
  • b: 右侧的结果向量。
  • rcond: 用来裁剪奇异值的一个参数(可以先设置为 None,默认行为会使用合理的值)

lstsq 函数返回四个值:

  • x: 最小二乘解,即满足 a @ x ≈ b 的解。
  • residuals: 残差的平方和。如果方程是过定的(更多的方程比未知数多),这个值才有意义。
  • rank: 矩阵 a 的秩。
  • s: a 的奇异值。
python">import numpy as np
a = np.array([[3, 1], [1, 2], [1, 1]])
b = np.array([9, 8, 6])
x, residuals, rank, s = np.linalg.lstsq(a, b, rcond=None)
print("求得的最小二乘解为:")
#round对数组中的每个元素进行四舍五入。4就是保留四位
print(np.round(x, 4))
两种方法的比较:
  • pinv 方法:先通过 np.linalg.pinv(a) 求解 a 的伪逆矩阵,再用矩阵乘法 @ 乘以向量 b 来得到最小二乘解。适合直接计算伪逆矩阵的场合。

  • lstsq 方法:直接求解最小二乘解,它比伪逆法更高效,因为它不需要显式计算伪逆矩阵,并且提供了残差、矩阵秩等额外信息。

  • 在数值精度和计算效率上,lstsq 通常表现得更好,尤其是当矩阵 a 较大时

结果:
在这里插入图片描述

什么是超定方程?

超定线性方程组(overdetermined system of linear equations)指的是方程的数量多于未知数的线性方程组。这意味着方程的数量 mmm 大于未知数的数量 nnn(即 m>nm > nm>n)。

特点:

  • 方程数量多于未知数:这类方程组往往没有精确的解,因为过多的方程对未知数施加了更多的约束条件,这些条件可能互相矛盾,无法同时满足。
  • 无法精确求解:由于不可能满足所有方程,通常需要使用最小二乘法等数值方法来找到使方程“近似成立”的解。这种解不是精确解,而是尽可能让方程残差(误差)最小的解。

例子:
在这里插入图片描述
在这里插入图片描述

求矩阵的特征值特征向量:

例1:
在这里插入图片描述
代码:

python">import numpy as np#它创建一个 4x4 的单位矩阵
#单位矩阵的定义是:对角线上(从左上到右下)所有元素为 1,其余元素为 0。
a = np.eye(4)
# a = [[1. 0. 0. 0.]
#      [0. 1. 0. 0.]
#      [0. 0. 1. 0.]
#      [0. 0. 0. 1.]]#将矩阵逆时针旋转 90 度
b = np.rot90(a)
# b = [[0. 0. 0. 1.]
#      [0. 0. 1. 0.]
#      [0. 1. 0. 0.]
#      [1. 0. 0. 0.]]#如果想顺时针旋转90度,加上一个参数k=-1;
# b=np.rot90(a,-1)
# b = [[0. 0. 0. 1.]
#      [0. 0. 1. 0.]
#      [0. 1. 0. 0.]
#      [1. 0. 0. 0.]]#顺时针旋转与逆时针旋转的关系:
#顺时针旋转 90 度相当于逆时针旋转 270 度。因此,你也可以通过 np.rot90(a, k=3) 达到相同的效果。
c, d = np.linalg.eig(b)
print('特征值为:', c)
print('特征向量为:\n', d)

结果:
在这里插入图片描述

Pandas库

在这里插入图片描述

生成二维数组:

例1:生成服从标准正态分布的24x4随机数矩阵,并保存为DataFrame数据结构

python">import pandas as pd
import numpy as np# 创建数据
dates = pd.date_range(start='20191101', end='20191124', freq='D')
a1 = pd.DataFrame(np.random.randn(24, 4), index=dates, columns=list('ABCD'))
a2 = pd.DataFrame(np.random.rand(24, 4))# 数据写入文件实例
a1.to_excel('data2_4_1.xlsx')  # 保存到 Excel
a2.to_csv('data2_4_2.csv')     # 保存到 CSV
#不包含行索引时
a1.to_excel('data2_4_1.xlsx', index=False)  # 保存到 Excel,不包含行索引
a2.to_csv('data2_4_2.csv', index=False)     # 保存到 CSV,不包含行索引

读写文件

在这里插入图片描述
例2:写入文件

python">import pandas as pd
import numpy as np# 创建数据
dates = pd.date_range(start='20191101', end='20191124', freq='D')
a1 = pd.DataFrame(np.random.randn(24, 4), index=dates, columns=list('ABCD'))
a2 = pd.DataFrame(np.random.rand(24, 4))# 数据写入文件实例
a1.to_excel('data2_4_1.xlsx')  # 保存到 Excel
a2.to_csv('data2_4_2.csv')     # 保存到 CSV
#不包含行索引时
a1.to_excel('data2_4_1.xlsx', index=False)  # 保存到 Excel,不包含行索引
a2.to_csv('data2_4_2.csv', index=False)     # 保存到 CSV,不包含行索引
# 使用 with 语句创建 ExcelWriter 对象
with pd.ExcelWriter('data2_4_3.xlsx') as writer:a1.to_excel(writer, sheet_name="Sheet1")  # 把a1写入Excel文件的Sheet1a2.to_excel(writer, sheet_name="Sheet2")  # 把a2写入另一个表单Sheet2
# 文件会自动保存和关闭,无需显式调用 save() 方法

结果:
在这里插入图片描述
在这里插入图片描述
如果写入数据时,不包含行索引:

python">import pandas as pd
import numpy as np# 创建数据
dates = pd.date_range(start='20191101', end='20191124', freq='D')
a1 = pd.DataFrame(np.random.randn(24, 4), index=dates, columns=list('ABCD'))
a2 = pd.DataFrame(np.random.rand(24, 4))#不包含行索引时
a1.to_excel('data2_4_4.xlsx', index=False)  # 保存到 Excel,不包含行索引   header=False  不包含列索引
a2.to_csv('data2_4_5.csv', index=False)     # 保存到 CSV,不包含行索引
# 使用 with 语句创建 ExcelWriter 对象
with pd.ExcelWriter('data2_4_6.xlsx') as writer:a1.to_excel(writer, sheet_name="Sheet1", index=False)  # 把a1写入Excel文件的Sheet1a2.to_excel(writer, sheet_name="Sheet2",index=False)  # 把a2写入另一个表单Sheet2

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

数据预处理:

在这里插入图片描述
例1:拆分,合并,分组计算

python">import pandas as pd
import numpy as np
d=pd.DataFrame(np.random.randint(1,6,(10,4)), columns=list("ABCD"))
d1=d[:4]  #获取前4行数据
d2=d[4:]  #获取第5行以后的数据
dd=pd.concat([d1,d2])   #数据行合并
s1=d.groupby('A').mean()      #数据分组求均值
s2=d.groupby('A').apply(sum)  #数据分组求和print(d,'\n')
print(d1,'\n')
print(d2,'\n')
print(dd,'\n')
print(s1,'\n')
print(s2,'\n')

结果:
在这里插入图片描述
在这里插入图片描述
例2:DataFrame数据操作示例
在这里插入图片描述

python">import pandas as pd
import numpy as np
a = pd.DataFrame(np.random.randint(1,6,(5,3)),index=['a', 'b', 'c', 'd', 'e'],columns=['one', 'two', 'three'])
a.loc['a', 'one'] = np.nan  #修改第1行第1列的数据
b = a.iloc[1:3, 0:2].values  #提取第2、3行,第1、2列数据
a['four'] = 'bar'  #增加第4列数据
a2 = a.reindex(['a', 'b', 'c', 'd', 'e', 'f'])
a3 = a2.dropna()   #删除有不确定值的行
print(a,'\n')
print(b,'\n')
print(a2,'\n')
print(a3,'\n')

在这里插入图片描述

SciPy库

模块功能表:
在这里插入图片描述

求解非线性方程组

求方程:
在这里插入图片描述
代码实现:

python">from scipy.optimize import fsolve, root
fx = lambda x:     x**980-5.01*x**979+7.398*x**978\-3.388*x**977-x**3+5.01*x**2-7.398*x+3.388
x1 = fsolve(fx, 1.5, maxfev=4000)  #函数调用4000次
x2 = root(fx, 1.5)
print(x1,'\n','-------------');print(x2)

在这里插入图片描述
注意:
在这里插入图片描述
例2:求下列方程组的一组数值解
在这里插入图片描述

python">from scipy.optimize import fsolve, root
fx = lambda x: [x[0]**2+x[1]**2-1, x[0]-x[1]]
#初始值为[1,1]
s1 = fsolve(fx, [1, 1])
s2 = root(fx, [1, 1])
print(s1,'\n','--------------'); print(s2)

在这里插入图片描述

积分:

例1:
在这里插入图片描述

python">from scipy.integrate import quad
def fun46(x, a, b):return a*x**2+b*x
I1 = quad(fun46, 0, 1, args=(2, 1))
I2 = quad(fun46, 0, 1, args=(2, 10))
print(I1); print(I2)

结果:
在这里插入图片描述
在这里插入图片描述

最小二乘解

在这里插入图片描述
例1:
在这里插入图片描述
在这里插入图片描述
代码:

python">from scipy.optimize import least_squares
import numpy as np
a=np.loadtxt('Z:\Code\python\建模培训2024\code\data2_47.txt')
x0=a[0]; y0=a[1]; d=a[2]
fx=lambda x: np.sqrt((x0-x[0])**2+(y0-x[1])**2)-d
s=least_squares(fx, np.random.rand(2))
print(s, '\n', '------------', '\n', s.x)

在这里插入图片描述

求矩阵最大模特征值与特征向量

在这里插入图片描述
代码:

python">from scipy.sparse.linalg import eigs
import numpy as npa = np.array([[1, 2, 3], [2, 1, 3], [3, 3, 6]], dtype=float)  #必须加float,否则出错
b, c = np.linalg.eig(a)
d, e = eigs(a, 1)
print('最大模特征值为:', d)
print('对应的特征向量为:\n', e)

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

SymPy库

定义符号变量或符号函数命令如下:
在这里插入图片描述

例1:求符号解

在这里插入图片描述

python">import sympy as sp
a, b, c, x=sp.symbols('a,b,c,x')
x0=sp.solve(a*x**2+b*x+c, x)
print(x0)

在这里插入图片描述

例2:求符号解

在这里插入图片描述
代码实现:

python">import sympy as sp
# sp.var('x1,x2')
# s=sp.solve([x1**2+x2**2-1,x1-x2],[x1,x2])
# print(s)
x1,x2=sp.symbols('x1,x2')
s=sp.solve([x1**2+x2**2-1,x1-x2],[x1,x2])
print(s)

在这里插入图片描述

例3:求矩阵的特征值与特征向量(符号解)

python">import numpy as np
import sympy as sp
a = np.identity(4)  #单位矩阵的另一种写法
b = np.rot90(a)
c = sp.Matrix(b)
print('特征值为:', c.eigenvals())
print('特征向量为:\n', c.eigenvects())

在这里插入图片描述

Matplotlib库

plot绘图常见的样式和颜色类型:
在这里插入图片描述
在这里插入图片描述
例1:
在这里插入图片描述代码:

python">import pandas as pd
import pylab as plt
plt.rc('font',family='SimHei')  #用来正常显示中文标签
plt.rc('font',size=16)  #设置显示字体大小
a=pd.read_excel("Z:\Code\python\建模培训2024\code\data2_52.xlsx", header=None)
b=a.values  #提取其中的数据
x=b[0]; y=b[1:]
#第三个参数。虚实线+形状+颜色
plt.plot(x,y[0],'-*b',label='钻石')
plt.plot(x,y[1],'--dr',label='铂金')
plt.xlabel('月份'); plt.ylabel('每月销量')
plt.legend(loc='upper left'); plt.grid(); plt.show()

在这里插入图片描述
例2:画出销售额的柱状图;

python">import pandas as pd
import pylab as plt
plt.rc('font',family='SimHei')  #用来正常显示中文标签
plt.rc('font',size=16)  #设置显示字体大小
a=pd.read_excel("Z:\Code\python\建模培训2024\code\data2_52.xlsx",header=None)
b=a.T
b.plot(kind='bar'); plt.legend(['钻石', '铂金'])
plt.xticks(range(6), b[0], rotation=0)
plt.ylabel('数量'); plt.show()

在这里插入图片描述

子图:

在这里插入图片描述
代码:

python">import pylab as plt
import numpy as np
plt.rc('font',family='SimHei')  #用来正常显示中文标签
plt.rc('axes',unicode_minus=False)
#生成随机数,进行归一化处理
y1=np.random.randint(2, 5, 6)
#使其和为1
y1=y1/sum(y1)
#创建第一个子图,水平条形图
# 在一个 2x2 的子图网格中创建第一个子图,位于第一个位置。
plt.subplot(2, 2, 1)
str=['苹果', '葡萄', '桃子', '梨', '香蕉', '菠萝']
plt.barh(str,y1)  #水平条形图
#创建第二个子图,饼图
plt.subplot(222)
plt.pie(y1, labels=str)  #饼图
#创建第三个子图,折线图
plt.subplot(212)
#生成一个包含 100 个点的数组,这些点均匀分布在 0.01 到 10 之间。
x2=np.linspace(0.01, 10, 100)
y2=np.sin(10*x2)/x2
plt.plot(x2,y2); plt.xlabel('$x$')
plt.ylabel('$\\mathrm{sin}(10x)/x$'); plt.show()

结果:
在这里插入图片描述

三维绘图

例1:三维曲线

在这里插入图片描述
代码:

python">import pylab as plt
import numpy as np
ax=plt.axes(projection='3d')  #设置三维图形模式
z=np.linspace(-50, 50, 1000)
x=z**2*np.sin(z); y=z**2*np.cos(z)
ax.plot(x, y, z, 'c')
plt.show()

在这里插入图片描述
例2:画出三维表面图:

python">import pylab as plt
import numpy as np
x=np.linspace(-4,4,100)
x,y=np.meshgrid(x,x)
z=50*np.sin(x+y)
ax=plt.axes(projection='3d')
ax.plot_surface(x, y, z, color='b')
plt.show()

在这里插入图片描述
例3:
在这里插入图片描述
代码:

python">import pylab as plt
import numpy as np
ax=plt.axes(projection='3d')
X = np.arange(-6, 6, 0.25)
Y = np.arange(-6, 6, 0.25)
X, Y = np.meshgrid(X, Y)
Z = np.sin(np.sqrt(X**2 + Y**2))
surf = ax.plot_surface(X, Y, Z, cmap='coolwarm')
#在图形旁边添加一个颜色条,用于表示不同颜色对应的 Z 值(即表面的高度)。
plt.colorbar(surf); plt.show()

在这里插入图片描述


http://www.ppmy.cn/news/1522759.html

相关文章

极米科技:走出舒适圈,推动数据架构现代化升级 | OceanBase 《DB大咖说》

《DB 大咖说》第 13 期,邀请到了极米科技软件与创新产品线高级架构师施刘凡来进行分享。 在小红书平台上,“是否应将家里的电视升级为投影仪?”这一话题激发了上百万篇笔记的分享与推荐,反映出年轻群体对投影仪的偏好。随着手机、…

【Linux】理解Linux中的软链接与硬链接

文章目录 理解Linux中的软链接与硬链接1. 什么是硬链接?示例: 2. 什么是软链接?示例: 3. 软链接与硬链接的对比4. 何时使用软链接与硬链接? 理解Linux中的软链接与硬链接 在Linux文件系统中,软链接&#x…

Android UI绘制流程

UI绘制流程,Activity、Dialog、PopupWindow等 -- android系统的事件分发流程分为很多部分: Native层 –> ViewRootImpl层 –> DecorView层 –> Activity层 –> ViewGroup层 –> View层。 其实Toast窗口和Activity、Dialog、PopupWindow有…

Java 中 `==` 和 `equals()` 的区别详解

在 Java 编程中, 和 equals() 是两种常用于比较变量和对象的方法。尽管它们都可以用来比较,但它们的作用和使用场景是不同的。本文将深入探讨它们之间的区别,并通过示例解释如何正确使用它们。 1. 操作符 什么是 ? 是 Java 中的…

24并发设计模式——线程池模式

一、线程池模式介绍 线程池模式(Thread Pool Pattern)是一种并发设计模式,用于管理和循环使用线程资源以处理大量任务。它旨在提高系统性能和资源利用率,特别是在需要频繁创建和销毁线程的环境中。 1、线程池模式结构图 线程池管…

wmv怎么转换成视频mp4?简单的几种视频格式转换方法

wmv怎么转换成视频mp4?在数字媒体日益普及的今天,我们经常会遇到需要转换视频格式的情况。wmv格式,由微软开发,广泛用于Windows平台上播放视频。尽管wmv格式在Windows系统中表现优异,但其兼容性在其他操作系统或设备上…

为什么我选择这款PR剪辑软件?打工人亲测好用!

现在大家都爱看短视频和Vlog,要是你会剪辑视频,那可就牛了。不管是出去玩拍的视频,还是工作需要,都能派上用场。我就是个爱旅行、爱剪辑的发烧友,今天给你们推荐三款特别好用的视频剪辑软件,尤其是PR剪辑&a…

Android 串口数据分包处理

/* class PacketHandler { private static final byte PACKET_START 0x79; // 假设包的开始标记为0x79 private static final byte PACKET_END 0x0D; // 假设包的结束标记为0x0D private static ByteArrayOutputStream buffer new ByteArrayOutputStream();public static v…

【前端】中断请求的方式

一 使用 Axios 和取消令牌 1.步骤: 初始化取消源,创建CancelToken const source axios.CancelToken.source();传递cancelToken, 发起请求 axios.get(/api/data, {cancelToken: source.token });触发取消请求 source.cancel(操作被取消);判断错误是否由于取消请求操作引起…

Vue.js 组件化开发:父子组件通信与组件注册详解

Vue.js 组件化开发:父子组件通信与组件注册详解 简介: 在 Vue.js 的开发中,组件是构建应用的重要基础。掌握组件的创建与使用,尤其是父子组件的通信和组件的注册与命名,是开发中不可或缺的技能。本文将详细探讨这些内容…

【前端】CSS控制style样式失效

在CSS中,可以通过几种方式控制或禁用特定的style样式。 使用all: unset来重置所有可继承的属性,并清除所有的样式: .element {all: unset;} 使用inherit值来使属性获取其父元素的值: .element {color: inherit;font-size: inh…

用Unity2D制作一个人物,实现移动、跳起、人物静止和动起来时的动画:中(人物移动、跳起、静止动作)

上回我们学到创建一个地形和一个人物,今天我们实现一下人物实现移动和跳起,依次点击,我们准备创建一个C#文件 创建好我们点击进去,就会跳转到我们的Vision Studio,然后输入这些代码 using UnityEngine;public class M…

Vue 使用接口返回的背景图片和拼图图片进行滑动拼图验证

一、背景 前两天发了一篇 vue-monoplasty-slide-verify 滑动验证码插件使用及踩坑_vue-monoplasty-slide-verify 引用后不显示-CSDN博客 这两天项目又需要通过接口校验,接口返回了背景图片和拼图图片,于是在网上找了一篇帖子,vue 图片滑动…

Apache Ignite 在处理大规模数据时有哪些优势和局限性?

Apache Ignite 在处理大规模数据时的优势和局限性可以从以下几个方面进行分析: 优势 高性能:Ignite 利用内存计算的优势,实现了极高的读写性能,通过分布式架构,它可以将数据分散到多个节点上,从而实现了并…

JavaEE-HTTPHTTPS

目录 HTTP协议 一、概念 二、http协议格式 http请求报文 http响应报文 URL格式 三、认识方法 四、认识报头 HTTP响应中的信息 HTTPS协议 对称加密 非对称加密 中间人攻击 解决中间人攻击 HTTP协议 一、概念 HTTP (全称为 "超⽂本传输协议") 是⼀种应⽤…

2024华为OD机试真题-反射计数Python-C卷D卷-200分

2024华为OD机试最新E卷题库-(C卷+D卷+E卷)-(JAVA、Python、C++) 目录 题目描述 输入描述 输出描述 用例1 题目解析 代码 题目描述 给定一个包含 0 和 1 的二维矩阵。 给定一个初始位置和速度,一个物体从给定的初始位置出发,在给定的速度下进行移动,遇到矩阵的边缘则…

分布式部署①

📑打牌 : da pai ge的个人主页 🌤️个人专栏 : da pai ge的博客专栏 ☁️宝剑锋从磨砺出,梅花香自苦寒来 1. 需要部署的服务 Nacos 理论上,应…

仕考网:事业编面试全流程介绍

1.进入考场 工作人员会检查考生的身份证、准考证以及随身携带物品,可以带食物和水 2.进入候考室 进入候考室,工作人员会再次确认考生信息 3.抽签 考生到齐后,工作人员会组织考生抽签,登记抽签序号、信息确认、发放号码牌 4.…

【Android】使用和风天气API获取天气数据吧!(天气预报系列之一)

【Android】使用和风天气API获取天气数据吧!(天气预报系列之一) 古话说得好,要有天气预报,首先需要有天气,和预报。 今天给大家介绍一个好用的天气预报API:和风天气。以及webAPI的使用方法~&a…

React 应用中集成 Ace Editor

安装 React-Ace 首先,你需要安装 react-ace 和 ace-builds(它包含 Ace Editor 的核心文件): pnpm install react-ace ace-builds用法: import React from react; import AceEditor from react-ace;// 引入你需要的 …