【Python】Numpy的使用

news2025/2/25 20:02:47

文章目录

    • 数组创建
    • 数组属性
    • ndarray数组索引
      • ndarray数组的基本索引和切片
      • ndarray数组的布尔索引
      • ndarray数组的花式索引
    • ndarray数组的转置和轴对换
    • ndarray通用函数
      • 一元ufunc
      • 二元ufunc
    • NumPy的where函数使用
    • 常用统计函数
      • 排序
    • ndarray数组的去重以及集合运算
    • numpy中的线性代数
    • numpy中的随机数生成
    • ndarray数组重塑
    • ndarray数组的拆分与合并
    • 数组的元素重复操作

numpy(Numerical Python)提供了python对 多维数组对象的支持:ndarray,具有矢量运算能力,快速、节省空间。numpy支持高级大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库。

import numpy

数组创建

ndarray:N维数组对象(矩阵),所有元素必须是相同类型。

函数说明
array将输入数据(列表、元组、数组或其他序列类型)转换为ndarray
asarray将输入转换为ndarray,如果输入本身就是一个ndarray就不进行复制
arange类似于内置的range,但返回的是一个ndarray而不是列表
ones,ones_like根据指定的形状和dtype创建一个全1数组。ones_like以另一个数组为参数,并根据其形状和dtype创建一个全1数组
zeros,zeros_like类似于ones和ones_like,只不过产生的是全0数组而已
empty,empty_like创建新数组,只分配内存空间但不填充任何值
eye,identity创建一个正方的NxN单位矩阵(对角线为1,其余为0)
import numpy
x = numpy.array([1,2,3,4,5,6])
print(x)
x = numpy.zeros(6)
print(x)
x = numpy.zeros((2,3))
print(x)
x = numpy.ones((2,3))
print(x)
x = numpy.empty((3,3))
print(x)
print('使用arrange生成连续元素')
print(numpy.arange(6)) # [0,1,2,3,4,5,] 开区间
print(numpy.arange(0,6,2))  # [0, 2,4]

numpy.array(object, dtype=None, copy=True, order='K',subok=False, ndmin=0)

参数名称说明
object接收array,表示想要创建的数组,无默认
dtype接收data-type,表示数组所需的数据类型。如果未给定,则选择保存对象所需的最小类型,默认为None
ndmin接收int,指定生成数组应该具有的最小维数,默认为None

dtype:

dtype

示例:

import numpy
print('生成指定元素类型的数组:设置dtype属性')
x = numpy.array([1, 2.6, 3], dtype=numpy.int64)
print(x)  # 元素类型为int64
print(x.dtype)
x = numpy.array([1, 2, 3], dtype=numpy.float64)
print(x)  # 元素类型为float64
print(x.dtype)

print('使用astype复制数组,并转换类型')
x = numpy.array([1, 2.6, 3], dtype=numpy.float64)
y = x.astype(numpy.int32)
print(y)  # [1 2 3]
print(x)  # [ 1.   2.6  3. ]
z = y.astype(numpy.float64)
print(z)  # [ 1.  2.  3.]

print('将字符串元素转换为数值元素')
x = numpy.array(['1', '2', '3'], dtype=numpy.string_)
y = x.astype(numpy.int32)
print(x)  # ['1' '2' '3']
print(y)  # [1 2 3] 若转换失败会抛出异常

print('使用其他数组的数据类型作为参数')
x = numpy.array([1., 2.6, 3.], dtype=numpy.float32);
y = numpy.arange(3, dtype=numpy.int32);
print(y)  # [0 1 2]
print(y.astype(x.dtype))  # [ 0.  1.  2.]

数组属性

ndarray是存储单一数据类型的多维数组

属性说明
ndim返回int,表示数组的维数
shape返回tuple,表示数组的尺寸。对于n行m列的矩阵,形状为(n,m)
size返回int,表示数组的元素总数,等于数组形状的乘积
dtype返回data-type,描述数组中元素的类型
itemsize返回int,表示数组的每个元素的大小(以字节为单位)
arr1 = numpy.array([[1,2,3],[4,5,6]])
print(arr1)
print(arr1.ndim)
print(arr1.shape)
print(arr1.size)
print(arr1.dtype)
print(arr1.itemsize)

ndarray数组索引

ndarray数组的基本索引和切片

一维数组的索引:与Python的列表索引功能相似

多维数组的索引:

  • arr[r1:r2, c1:c2]
  • arr[1,1] 等价 arr[1][1]
  • [:] 代表某个维度的数据
import numpy
print('ndarray的基本索引')
x = numpy.array([[1, 2], [3, 4], [5, 6]])
print(x[0])  # [1,2]
print(x[0][1])  # 2,普通python数组的索引
print(x[0, 1])  # 同x[0][1],ndarray数组的索引
x = numpy.array([[[1, 2], [3, 4]], [[5, 6], [7, 8]]])
print(x[0])  # [[1 2],[3 4]]
y = x[0].copy()  # 生成一个副本
z = x[0]  # 未生成一个副本
print(y)  # [[1 2],[3 4]]
print(y[0, 0])  # 1
y[0, 0] = 0
z[0, 0] = -1
print(y)  # [[0 2],[3 4]]
print(x[0])  # [[-1 2],[3 4]]
print(z)  # [[-1 2],[3 4]]

print('ndarray的切片')
x = numpy.array([1, 2, 3, 4, 5])
print(x[1:3])  # [2,3] 右边开区间
print(x[:3])  # [1,2,3] 左边默认为 0
print(x[1:])  # [2,3,4,5] 右边默认为元素个数
print(x[0:4:2])  # [1,3] 下标递增2
x = numpy.array([[1, 2], [3, 4], [5, 6]])
print(x[:2])  # [[1 2],[3 4]]
print(x[:2, :1])  # [[1],[3]]
x[:2, :1] = 0  # 用标量赋值
print(x)  # [[0,2],[0,4],[5,6]]
x[:2, :1] = [[8], [6]]  # 用数组赋值
print(x)  # [[8,2],[6,4],[5,6]]

ndarray数组的布尔索引

布尔索引:使用布尔数组作为索引。arr[condition],condition为一个条件/多个条件组成的布尔数组。

import numpy
print('ndarray的布尔型索引')
x = numpy.array([3,2,3,1,3,0])
# 布尔型数组的长度必须跟被索引的轴长度一致
y = numpy.array([True,False,True,False,True,False])
print(x[y]) # [3,3,3]
print(x[y==False]) # [2,1,0]
print(x>=3) # [ True False  True False  True  False]
print(x[~(x>=3)]) # [2,1,0]
print((x==2)|(x==1)) # [False  True False  True False False]
print(x[(x==2)|(x==1)]) # [2 1]
x[(x==2)|(x==1)] = 0
print(x) # [3 0 3 0 3 0]

ndarray数组的花式索引

花式索引:使用整型数组作为索引。

import numpy
print('ndarray的花式索引:使用整型数组作为索引')
x = numpy.array([1,2,3,4,5,6])
print(x[[0,1,2]]) # [1 2 3]
print(x[[-1,-2,-3]]) # [6,5,4]
x = numpy.array([[1,2],[3,4],[5,6]])
print(x[[0,1]]) # [[1,2],[3,4]]
print(x[[0,1],[0,1]]) # [1,4] 打印x[0][0]和x[1][1]
print(x[[0,1]][:,[0,1]]) # 打印01行的01列 [[1,2],[3,4]]
# 使用numpy.ix_()函数增强可读性
print(x[numpy.ix_([0,1],[0,1])]) #同上 打印01行的01列 [[1,2],[3,4]]
x[[0,1],[0,1]] = [0,0]
print(x) # [[0,2],[3,0],[5,6]]

ndarray数组的转置和轴对换

数组的转置/轴对换只会返回源数据的一个视图,不会对源数据进行修改。

import numpy
print('ndarray数组的转置和轴对换')
k = numpy.arange(9) #[0,1,....8]
m = k.reshape((3,3)) # 改变数组的shape复制生成2维的,每个维度长度为3的数组
print(k) # [0 1 2 3 4 5 6 7 8]
print(m) # [[0 1 2] [3 4 5] [6 7 8]]
# 转置(矩阵)数组:T属性 : mT[x][y] = m[y][x]
print(m.T) # [[0 3 6] [1 4 7] [2 5 8]]
# 计算矩阵的内积 xTx
print(numpy.dot(m,m.T)) # numpy.dot点乘
# 高维数组的轴对象
k = numpy.arange(8).reshape(2,2,2)
print(k) # [[[0 1],[2 3]],[[4 5],[6 7]]]
print(k[1][0][0])
# 轴变换 transpose 参数:由轴编号组成的元组
m = k.transpose((1,0,2)) # m[y][x][z] = k[x][y][z]
print(m) # [[[0 1],[4 5]],[[2 3],[6 7]]]
print(m[0][1][0])
# 轴交换 swapaxes (axes:轴),参数:一对轴编号
m = k.swapaxes(0,1) # 将第一个轴和第二个轴交换 m[y][x][z] = k[x][y][z]
print(m) # [[[0 1],[4 5]],[[2 3],[6 7]]]
print(m[0][1][0])
# 使用轴交换进行数组矩阵转置
m = numpy.arange(9).reshape((3,3))
print(m) # [[0 1 2] [3 4 5] [6 7 8]]
print(m.swapaxes(1,0)) # [[0 3 6] [1 4 7] [2 5 8]]

ndarray通用函数

通用函数(ufunc)是一种对ndarray中的数据执行元素级运算的函数。

一元ufunc

一元ufunc

代码示例:

import numpy
print('一元ufunc示例')
x = numpy.arange(6)
print(x) # [0 1 2 3 4 5]
print(numpy.square(x)) # [ 0  1  4  9 16 25]
x = numpy.array([1.5,1.6,1.7,1.8])
y,z = numpy.modf(x)
print(y) # [ 0.5  0.6  0.7  0.8]
print(z) # [ 1.  1.  1.  1.]

二元ufunc

二元ufunc

代码示例:

import numpy
print('二元ufunc示例')
x = numpy.array([[1,4],[6,7]])
y = numpy.array([[2,3],[5,8]])
print(numpy.maximum(x,y)) # [[2,4],[6,8]]
print(numpy.minimum(x,y)) # [[1,3],[5,7]]

NumPy的where函数使用

np.where(condition, x, y),第一个参数为一个布尔数组,第二个参数和第三个参数可以是标量也可以是数组。

代码示例:

import numpy
print('where函数的使用')
cond = numpy.array([True,False,True,False])
x = numpy.where(cond,-2,2)
print(x) # [-2  2 -2  2]
cond = numpy.array([1,2,3,4])
x = numpy.where(cond>2,-2,2)
print(x) # [ 2  2 -2 -2]
y1 = numpy.array([-1,-2,-3,-4])
y2 = numpy.array([1,2,3,4])
x = numpy.where(cond>2,y1,y2) # 长度须匹配
print(x) # [1,2,-3,-4]

print('where函数的嵌套使用')
y1 = numpy.array([-1,-2,-3,-4,-5,-6])
y2 = numpy.array([1,2,3,4,5,6])
y3 = numpy.zeros(6)
cond = numpy.array([1,2,3,4,5,6])
x = numpy.where(cond>5,y3,numpy.where(cond>2,y1,y2))
print(x) # [ 1.  2. -3. -4. -5.  0.]

常用统计函数

函数说明
sum计算数组的和
mean计算数组均值
std计算数组标准差
var计算数组方差
min计算数组最小值
max计算数组最大值
argmin返回数组最小元素的索引
argmax返回数组最大元素的索引
cumsum计算所有元素的累计和
cumprod计算所有元素的累计积

代码示例:

import numpy
print('numpy的基本统计方法')
x = numpy.array([[1,2],[3,3],[1,2]]) #同一维度上的数组长度须一致
print (x.mean()) # 2
print (x.mean(axis=1)) # 对每一行的元素求平均
print (x.mean(axis=0)) # 对每一列的元素求平均
print (x.sum()) #同理 12
print (x.sum(axis=1)) # [3 6 3]
print (x.max()) # 3
print (x.max(axis=1)) # [2 3 2]
print (x.cumsum()) # [ 1  3  6  9 10 12]
print (x.cumprod()) # [ 1  2  6 18 18 36]

用于布尔数组的统计方法:

  • sum : 统计数组/数组某一维度中的True的个数
  • any: 统计数组/数组某一维度中是否存在一个/多个True
  • all:统计数组/数组某一维度中是否都是True

代码示例:

import numpy
print('用于布尔数组的统计方法')
x = numpy.array([[True,False],[True,False]])
print(x.sum()) # 2
print(x.sum(axis=1)) # [1,1]
print(x.any(axis=0)) # [True,False]
print(x.all(axis=1)) # [False,False]

排序

arr.sort()

sort函数也可以指定一个axis参数,使得sort函数可以沿着指定轴对数据集进行排序。

axis=1为沿横轴排序;axis=0为沿纵轴排序

sorted(arr)

sorted 并没有修改原来的数组,而是将排序的结果作为参数传递给一个新的数组,而 sort 则在原数组上直接进行了排序

ndarray数组的去重以及集合运算

方法说明
unique(x)计算x中的唯一元素,并返回有序结果
intersect1d(x,y)计算x和y中的公共元素,并返回有序结果
union1d(x,y)计算x和y的并集,并返回有序结果
in1d(x,y)得到一个表示"x的元素是否包含于y"的布尔型数组
setdiff1d(x,y)集合的差,即元素在x中且不在y中
setxor1d(x,y)集合的对称差,即存在一个数组中但不同时存在两个数组中的元素

代码示例:

import numpy
print('ndarray的唯一化和集合运算')
x = numpy.array([[1,6,2],[6,1,3],[1,5,2]])
print(numpy.unique(x)) # [1,2,3,5,6]
y = numpy.array([1,6,5])
print(numpy.in1d(x,y)) # [ True  True False  True  True False  True  True False]
print(numpy.setdiff1d(x,y)) # [2 3]
print(numpy.intersect1d(x,y)) # [1 5 6]

numpy中的线性代数

创建与组合矩阵

使用mat函数创建矩阵:matr1 = numpy.mat("1 2 3;4 5 6;7 8 9")

使用matrix函数创建矩阵:matr2 = numpy.matrix([[1,2,3],[4,5,6],[7,8,9]])

使用bmat函数合成矩阵:matr3 = numpy.bmat("matr1 matr2; matr1 matr2")

矩阵的运算

矩阵与数相乘:matr1*3

矩阵相加减:matr1+matr2 matr1-matr2

矩阵相乘:matr1*matr2

矩阵对应元素相乘:numpy.multiply(matr1,matr2)

矩阵特有属性

属性说明
T返回自身的转置
H返回自身的共轭转置
I返回自身的逆矩阵
A返回自身数据的2维数组的一个视图

import numpy.linalg

函数说明
diag以一维数组的形式返回方阵的对角线(或非对角线)元素,或将一维数组转换为方阵(非对角线元素为0)
dot矩阵乘法
trace计算对角线元素的和
det计算矩阵行列式
eig计算方阵的本征值和本征向量
inv计算方阵的逆
pinv计算矩阵的Moore-Penrose伪逆
qr计算QR分解
svd计算奇异值分解(SVD)
solve解线性方程组Ax=b,其中A为一个方阵
lstsq计算Ax=b的最小二乘解

代码示例:

import numpy
import numpy.linalg as nla
print('线性代数')
print('矩阵点乘')
x = numpy.array([[1,2],[3,4]])
y = numpy.array([[1,3],[2,4]])
print(x.dot(y)) # [[ 5 11][11 25]]
print(numpy.dot(x,y)) # # [[ 5 11][11 25]]
print('矩阵求逆')
x = numpy.array([[1,1],[1,2]])
y = nla.inv(x) # 矩阵求逆(若矩阵的逆存在)
print(x.dot(y)) # 单位矩阵 [[ 1.  0.][ 0.  1.]]
print(nla.det(x)) # 求行列式

numpy中的随机数生成

import numpy.random

函数说明
seed确定随机数生成器的种子
permutation返回一个序列的随机排列或返回一个随机排列的范围
shuffle对一个序列就地随机排列
rand产生均匀分布的样本值
randint从给定的上下限范围内随机选取整数
randn产生正态分布(平均值为0,标准差为1)的样本值,类似于MATLAB接口
binomial产生二项分布的样本值
normal产生正态(高斯)分布的样本值
beta产生Beta分布的样本值
chisquare产生卡方分布的样本值
gamma产生Gamma分布的样本值
uniform产生在[0,1)中均匀分布的样本值

代码示例:

# 无约束条件下生成随机数
print(numpy.random.random(100))
# 生成服从均匀分布的随机数
print(numpy.random.rand(10,5))

ndarray数组重塑

import numpy
print('ndarray数组重塑')
x = numpy.arange(0,6) #[0 1 2 3 4]
print(x) #[0 1 2 3 4]
print(x.reshape((2,3))) # [[0 1 2][3 4 5]]
print(x) #[0 1 2 3 4]
print(x.reshape((2,3)).reshape((3,2))) # [[0 1][2 3][4 5]]
y = numpy.array([[1,1,1],[1,1,1]])
x = x.reshape(y.shape)
print(x) # [[0 1 2][3 4 5]]
print(x.flatten()) # [0 1 2 3 4 5]
x.flatten()[0] = -1 # flatten返回的是拷贝
print(x) # [[0 1 2][3 4 5]]
print(x.ravel()) # [0 1 2 3 4 5]
x.ravel()[0] = -1 # ravel返回的是视图(引用)
print(x) # [[-1 1 2][3 4 5]]
print("维度大小自动推导")
arr = numpy.arange(15)
print(arr.reshape((5, -1))) # 15 / 5 = 3

ndarray数组的拆分与合并

类型说明
concatenate最一般化的连接,沿一条轴连接一组数组
vstack,row_stack以面向行的方式对数组进行堆叠(沿轴0)
hstack以面向行的方式对数组进行堆叠(沿轴1)
column_stack类似于hstack,但是会先将一维数组转换为二维列向量
dstack以面向“深度”的方式对数组进行堆叠(沿轴2)
split沿指定轴在指定的位置拆分数组
hsplit, vsplit, dsplitsplit的便捷化函数,分别沿着轴0、轴1和轴2进行拆分

代码示例:

import numpy
print('数组的合并与拆分')
x = numpy.array([[1, 2, 3], [4, 5, 6]])
y = numpy.array([[7, 8, 9], [10, 11, 12]])
print(numpy.concatenate([x, y], axis = 0))
# 竖直组合 [[ 1  2  3][ 4  5  6][ 7  8  9][10 11 12]]
print(numpy.concatenate([x, y], axis = 1))
# 水平组合 [[ 1  2  3  7  8  9][ 4  5  6 10 11 12]]
print('垂直stack与水平stack')
print(numpy.vstack((x, y))) # 垂直堆叠:相对于垂直组合
print(numpy.hstack((x, y))) # 水平堆叠:相对于水平组合
# dstack:按深度堆叠
print(numpy.split(x,2,axis=0))
# 按行分割 [array([[1, 2, 3]]), array([[4, 5, 6]])]
print(numpy.split(x,3,axis=1))
# 按列分割 [array([[1],[4]]), array([[2],[5]]), array([[3],[6]])]

# 堆叠辅助类
import numpy as np
arr = np.arange(6)
arr1 = arr.reshape((3, 2))
arr2 = np.random.randn(3, 2)
print('r_用于按行堆叠')
print(np.r_[arr1, arr2])
print('c_用于按列堆叠')
print(np.c_[np.r_[arr1, arr2], arr])
print('切片直接转为数组')
print(np.c_[1:6, -10:-5])

数组的元素重复操作

import numpy
print('数组的元素重复操作')
x = numpy.array([[1,2],[3,4]])
print(x.repeat(2)) # 按元素重复 [1 1 2 2 3 3 4 4]
print(x.repeat(2,axis=0)) # 按行重复 [[1 2][1 2][3 4][3 4]]
print(x.repeat(2,axis=1)) # 按列重复 [[1 1 2 2][3 3 4 4]]
x = numpy.array([1,2])
print(numpy.tile(x,2)) # tile瓦片:[1 2 1 2]
print(numpy.tile(x, (2, 2)))  # 指定从低维到高维依次复制的次数。
# [[1 2 1 2][1 2 1 2]]

参考博文:https://blog.csdn.net/cxmscb/article/details/54583415

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

优思学院|如何选择六西格玛黑带的项目?

不管六西格玛的实施着重于变革式的还是渐进式的目标,项目都是六西格玛最核心的部分。选择和使用组织中最好的人才本身并不一定能保证达到最好的结果,项目的选取是领导层无可推卸的责任。选择一个项目意味着什么?领导团队必须将无数的问题、困…

DAC测试实验——FPGA学习比

一、DAC简介 DAC全称Digital to Analog Converter,即数模转换器。它用于将主控芯片产生的数字值(0和1)转换为模拟值(电压值)。 1、DAC参数指标 2、DAC类型 常用的DAC可大致分为权电阻网络DAC、T型电阻网络DAC、倒T型电阻网络DAC以及权电流型DAC。 3、AD9708/3PD9…

html中a标签的多用性

在HTML中&#xff0c;<a> 标签&#xff08;通常称为锚标签或链接标签&#xff09;具有多种用途和强大的功能。以下是<a>标签的一些主要多用性&#xff1a; 网页间的导航&#xff1a; 这是<a>标签最常见的用途。通过href属性&#xff0c;可以指定一个URL&am…

【问题解决】国际化messages_zh_CN.properties中乱码问题

打开 messages_zh_CN.properties 文件 之前用中文写的现在都是各种各样的符号 解决方法&#xff1a; 打开idea 找到File>Settings>Editor>File Encodings 确定这三个地方是否都是utf-8&#xff0c;改好之后点确定&#xff0c;就能正常显示了

吴恩达深度学习笔记:机器学习(ML)策略(1)(ML strategy(1))1.9-1.10

这里写自定义目录标题 第三门课 结构化机器学习项目&#xff08;Structuring Machine Learning Projects&#xff09;第一周 机器学习&#xff08;ML&#xff09;策略&#xff08;1&#xff09;&#xff08;ML strategy&#xff08;1&#xff09;&#xff09;1.9 可避免偏差&am…

红队内网攻防渗透:内网渗透之Linux内网权限提升技术:udf提权Capability权限LD_PRELOAD环境变量

红队内网攻防渗透 1. 内网权限提升技术1.1 Linux系统提权-Web&用户-数据库udf提权1.1.1 信息收集1.1.2 Web权限获取1.1.3 MYSQL-UDF提权1.1.4 下载到目标上1.1.5 连接确认是否有条件进行导出调用1.1.6 开始进行写入导出调用1.2 Linux系统提权-Web&用户-Capability能力1…

高分论文密码---大尺度空间模拟预测与数字制图

大尺度空间模拟预测和数字制图技术和不确定性分析广泛应用于高分SCI论文之中&#xff0c;号称高分论文密码。大尺度模拟技术可以从不同时空尺度阐明农业生态环境领域的内在机理和时空变化规律&#xff0c;又可以为复杂的机理过程模型大尺度模拟提供技术基础。我们将结合一些经典…

JDK8时间类,时区,时间和格式化

一.时间类 二.获取所有的时区 1.获取所有的时区Set<String> zoneIds ZoneId.getAvailableZoneIds();System.out.println(zoneIds.size()); 根据打印的结果可以看到java类中一共有603个时区。 三.获取当前系统默认的时区 ZoneId zoneId ZoneId.systemDefault();Syste…

测试基础13:测试用例设计方法-错误推断、因果图判定表

课程大纲 1、错误推测法 靠主观经验和直觉来推测可能容易出现问题的功能或场景&#xff0c;设计相关测试用例进行验证。 2、因果图&判定表 2.1定义 因果图和判定表是分析和表达多逻辑条件下&#xff0c;执行不同操作的情况的工具。 &#xff08;因果图和判定表配合使用&a…

20.2 JSON-JSON解码、映射数据类型、处理JSON响应

1. JSON解码 JSON解码&#xff0c;即将JSON格式在字符串转换为Go语言数据类型的变量。 函数Unmarshal接受一个JSON字节切片和一个指定目标格式的接口。而这个借口即与JSON字符串中的结果相匹配的结构体类型的变量。 定义结构体类型 type Person struct { ... }创建结构体变量…

Internet Download Manager(IDM6.41)安装教程+软件安装包下载

IDM是一款多线程下载工具&#xff0c;全称InternetDownloadManager。IDM的多线程加速功能&#xff0c;能够充分利用宽带&#xff0c;所以下载速度会比较快&#xff0c;而且它支持断点续传。它的网站音视频捕获、站点抓取、静默下载等功能&#xff0c;也特别实用。 安 装 包 获 …

堆的实现及其应用

堆的概念 堆是完全二叉树&#xff0c;分为大堆和小堆。大堆&#xff1a;任何一个父亲都大于等于孩子&#xff0c;小堆&#xff1a;任何一个父亲都小于等于孩子。 堆的实现 目录 typedef int HPDataType;typedef struct Heap { HPDataType* a;int size;int capacity; }HP;//交…

java写一个验证码

生成验证码 内容&#xff1a;可以是小写字母&#xff0c;也可以是大写字母&#xff0c;还可以是数字 规则 长度为5 内容中是四位字母&#xff0c;1位数字。 其中数字只有1位&#xff0c;但是可以出现在任意的位置。 package User;import java.util.ArrayList; import jav…

MFC动态创建按钮

void CMFCApplication1Dlg::OnBnClickedOk() {for (int i 0; i < 100; i){for (int j 0; j < 100; j){CButton* pButton3 new CButton;pButton[i][j] pButton3;}}CRect rect;GetClientRect(&rect); // 获取对话框客户区的大小rect.top 10; // 设置按钮的位置rec…

【培训】企业档案管理专题(私货)

导读&#xff1a;通过该专题培训&#xff0c;可以系统了解企业档案管理是什么、为什么、怎么做。尤其是对档案的价值认知&#xff0c;如何构建与新质生产力发展相适应的企业档案工作体系将有力支撑企业新质生产力的发展&#xff0c;为企业高质量发展贡献档案力量&#xff0c;提…

02-adb的工作原理和常见命令

一、什么是adb&#xff1f; ADB 是 Android Debug Bridge 的简称&#xff0c;是 Android 平台的调试工具。通过 adb 命令可以去获取安卓设备上的一些信息&#xff0c;也可以直接操作管理 Android 模拟器或者真实的 Android 设备。 ADB 采用客户端-服务端程序架构&#xff0c;简…

12306 火车票价格解析 (PHP 解析)

1. 从接口拿数据 日期 出发站 终点站 都填上 xxx/otn/leftTicketPrice/queryAllPublicPrice?leftTicketDTO.train_date2024-06-15&leftTicketDTO.from_stationBJP&leftTicketDTO.to_stationSJP&purpose_codesADULT 返回的数据是这样的 {"validateMess…

格式工厂转换mp3失败,原因和解决方法来了

在使用格式工厂进行音频转换时&#xff0c;有时候可能会遇到转换为MP3失败的问题。这可能会让人感到困扰&#xff0c;但幸运的是&#xff0c;这样的问题通常有一些常见的原因&#xff0c;而且大多数情况下都能够轻松解决。在本文中&#xff0c;我们将探讨一些可能导致格式工厂转…

【Linux】高级IO——五种IO方式,select,poll,epoll

文章目录 一、简单了解什么是IO及五种IO模式五种IO同步IO和异步IO区别1.阻塞IO&#xff08;张三钓鱼方式&#xff09;2.非阻塞IO非阻塞轮询&#xff08;李四钓鱼方式&#xff09;使用fcntl函数实现SetNonBlock非阻塞 二、IO多路转接——select&#xff08;赵六钓鱼方式&#xf…

HTML静态网页成品作业(HTML+CSS)—— 家乡成都介绍网页(4个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有4个页面。 二、作品演示 三、代…