基于PaddlePaddle2.2的数据建模研究助手

本项目基于PaddlePaddle2.2,在波士顿房价预测案例基础上优化,增加epoch与loss对应图及最低loss时epoch-id函数以找最佳参数,用相关系数评价回归结果。通过数据探索分析、预处理、建模训练、预测等步骤,对比数据打乱与否的效果,揭示机器学习与传统拟合的区别,还包含模型应用及结果可视化。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

基于paddlepaddle2.2的数据建模研究助手 - 创想鸟

基于PaddlePaddle2.2的数据建模研究助手

1.项目背景

PaddlePaddle拥有强大的大数据处理能力。

paddle.nn 目录下包含飞桨框架支持的神经网络层和相关函数的相关API。

https://www.paddlepaddle.org.cn/documentation/docs/zh/api/paddle/nn/Overview_cn.html#juanjiceng

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

应用paddle.nn 可以构建数据回归模型,进行大数据分析。

本项目基于PaddlePaddle2.2在预测波士顿房价的案例基础上,增加了epoch与loss的对应图以及求最低loss时epoch-id的函数,从而找到最佳的模型参数,为建模调参提供帮助。

预测波士顿房价的案例连接如下:https://www.paddlepaddle.org.cn/documentation/docs/zh/practices/quick_start/linear_regression.html

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

此外,本项目使用相关系数对回归结果进行评价。

2.环境设置

In [1]

import paddleimport numpy as npimport osimport matplotlibimport matplotlib.pyplot as pltimport pandas as pdimport seaborn as snsimport warningswarnings.filterwarnings("ignore")print(paddle.__version__)

   

3.数据导入

In [2]

#下载数据!wget https://archive.ics.uci.edu/ml/machine-learning-databases/housing/housing.data -O housing.data

   In [3]

# 从文件导入数据datafile = './housing.data'housing_data = np.fromfile(datafile, sep=' ')feature_names = ['CRIM', 'ZN', 'INDUS', 'CHAS', 'NOX', 'RM', 'AGE','DIS', 'RAD', 'TAX', 'PTRATIO', 'B', 'LSTAT', 'MEDV']feature_num = len(feature_names)# 将原始数据进行Reshape,变成[N, 14]这样的形状housing_data = housing_data.reshape([housing_data.shape[0] // feature_num, feature_num])

   

4.数据探索性分析

数据建模前,需要对数据进行探索性分析。

探索性分析主要是通过数据可视化(绘图)以及相关性分析来了解数据规律(自变量和因变量的函数关系)

In [4]

# 画图看特征间的关系,主要是变量两两之间的关系(线性或非线性,有无明显较为相关关系)features_np = np.array([x[:13] for x in housing_data], np.float32)labels_np = np.array([x[-1] for x in housing_data], np.float32)df = pd.DataFrame(housing_data, columns=feature_names)matplotlib.use('TkAgg')%matplotlib inlinesns.pairplot(df.dropna(), y_vars=feature_names[-1], x_vars=feature_names[::1], diag_kind='kde')plt.show()

   In [5]

# 相关性分析fig, ax = plt.subplots(figsize=(15, 1)) corr_data = df.corr().iloc[-1]corr_data = np.asarray(corr_data).reshape(1, 14)ax = sns.heatmap(corr_data, cbar=True, annot=True)plt.show()

   

5.数据预处理

在数据回归时,若数据数值差异太大,会导致模型参数不收敛。因此需要对数据进行归一化处理。

本项目只对属性值(自变量)进行归一化处理,房价(因变量)没有归一化。

注意:若对房价(因变量)进行了数据预处理,计算结果务必进行数据逆处理,否则会导致预测值和原值差异极大,严重时模型参数无法收敛

In [6]

#归一化前,数据数值差异极大sns.boxplot(data=df.iloc[:, 0:13])

   In [7]

#定义归一化方法features_max = housing_data.max(axis=0)features_min = housing_data.min(axis=0)features_avg = housing_data.sum(axis=0) / housing_data.shape[0]def feature_norm(input):    f_size = input.shape    output_features = np.zeros(f_size, np.float32)    for batch_id in range(f_size[0]):        for index in range(13):            output_features[batch_id][index] = (input[batch_id][index] - features_avg[index]) / (features_max[index] - features_min[index])    return output_features

   In [8]

# 只对属性进行归一化housing_features = feature_norm(housing_data[:, :13])# print(feature_trian.shape)housing_data = np.c_[housing_features, housing_data[:, -1]].astype(np.float32)# print(training_data[0])

   In [9]

# 归一化后的train_data, 看下各属性的情况features_np = np.array([x[:13] for x in housing_data],np.float32)labels_np = np.array([x[-1] for x in housing_data],np.float32)data_np = np.c_[features_np, labels_np]df = pd.DataFrame(data_np, columns=feature_names)sns.boxplot(data=df.iloc[:, 0:13])

   

6.机器学习

6.1 构建训练数据集和测试数据集

In [10]

# 将训练数据集和测试数据集按照8:2的比例分开ratio = 0.8offset = int(housing_data.shape[0] * ratio)train_data = housing_data[:offset]test_data = housing_data[offset:]

   

6.2 确定每轮训练过程中,每批次投入的数据量

每批次投入的数据量越多,模型回归的计算量变大,计算速度变小,无法收敛的可能性也增大。

但若每批次投入的数据量过少,那么模型的准确度会变差。

In [11]

# 确定每轮训练过程中,每批次投入的数据量bratio=0.2 #数据投喂比例BATCH_SIZE = int(len(train_data)*bratio)

   

6.3 搭建数据模型(组网)

paddle.nn 目录下包含飞桨框架支持的神经网络层和相关函数的相关API。

https://www.paddlepaddle.org.cn/documentation/docs/zh/api/paddle/nn/Overview_cn.html#juanjiceng

替换、增加、减少paddle.nn 的函数,调节函数中的参数,都会改变数据模型,而数据模型决定了预测的准确度。

JTopCms建站系统 JTopCms建站系统

JTopCMS基于JavaEE自主研发,是用于管理站群内容的国产开源软件(CMS),能高效便捷地进行内容采编,审核,模板制作,用户交互以及文件等资源的维护。安全,稳定,易扩展,支持国产中间件及数据库,适合建设政府,教育以及企事业单位的站群系统。 系统特色 1. 基于 JAVA 标准自主研发,支持主流国产信创环境,国产数据库以及国产中间件。安全,稳定,经过多次政务与企事业单位项目长期检验,顺利通过

JTopCms建站系统 0 查看详情 JTopCms建站系统 In [12]

import paddleimport paddle.nn.functional as Fclass LeNet(paddle.nn.Layer):    def __init__(self):         super(LeNet, self).__init__()        # 形状变换,将数据形状从多维变为1维度         #self.flatten = paddle.nn.Flatten()        # 第一个全连接层         self.linear1 = paddle.nn.Linear(in_features=13, out_features=10)#         # 使用ReLU激活函数         self.act1 = paddle.nn.Softplus()#         # 第二个全连接层         self.linear2 = paddle.nn.Linear(in_features=10, out_features=1)#         # 使用ReLU激活函数         #self.act2 = paddle.nn.ReLU()#         # 第三个全连接层         #self.linear3 = paddle.nn.Linear(in_features=20, out_features=1)             def forward(self, x):         #x = self.flatten(x)         x = self.linear1(x)         x = self.act1(x)         x = self.linear2(x)         #x = self.act2(x)         #x = self.linear3(x)         return xmodel = LeNet()

   In [13]

#设置模型的优化方法optimizer = paddle.optimizer.SGD(learning_rate=0.001, parameters=model.parameters())

   

6.4 模型训练

利用数据训练集的房价(因变量)和归一化后的属性值(自变量)进行模型训练。

把自变量代入模型函数,计算出预测值,然后计算出预测值和真实值的均方差(mse_loss),并据此使用优化器对模型参数进行优化。

In [14]

import paddle.nn.functional as F y_preds = []labels_list = []train_nums = []train_costs = []def train(model):    print('start training ... ')    # 开启模型训练模式    model.train()    EPOCH_NUM = 500 #设置训练轮数    train_num = 0        for epoch_id in range(EPOCH_NUM):        # 在每轮迭代开始之前,将训练数据的顺序随机的打乱        np.random.shuffle(train_data)        # 将训练数据进行拆分,每个batch包含BATCH_SIZE条数据        mini_batches = [train_data[k: k+BATCH_SIZE] for k in range(0, len(train_data), BATCH_SIZE)]        for batch_id, data in enumerate(mini_batches):            features_np = np.array(data[:, :13], np.float32)            labels_np = np.array(data[:, -1:], np.float32)            features = paddle.to_tensor(features_np)            labels = paddle.to_tensor(labels_np)                        # 前向计算            y_pred = model(features)            cost = F.mse_loss(y_pred, label=labels)#默认reduction='mean'            train_cost = cost.numpy()[0]            # 反向传播            cost.backward()            # 最小化loss,更新参数            optimizer.step()            # 清除梯度            optimizer.clear_grad()                        if epoch_id%5 == 0: #训练轮数为500,每5轮保存一次参数                print("Pass:%d,Cost:%0.5f"%(epoch_id, train_cost))                # save state_dict                paddle.save(model.state_dict(),'./checkpoint/epoch{}.pdparams'.format(epoch_id))                paddle.save(optimizer.state_dict(),'./checkpoint/epoch{}.pdopt'.format(epoch_id))            train_num = train_num + BATCH_SIZE            train_nums.append(train_num)            train_costs.append(train_cost)        train(model)

   

绘制模型训练过程图

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

In [15]

def draw_train_process(iters, train_costs):    plt.title("training cost", fontsize=24)    plt.xlabel("iter", fontsize=14)    plt.ylabel("cost", fontsize=14)    plt.plot(iters, train_costs, color='red', label='training cost')    plt.show()matplotlib.use('TkAgg')%matplotlib inlinedraw_train_process(train_nums, train_costs)

   

6.5 模型预测

本项目把保存的参数依次加载到模型,然后用模型及相应参数对测试数据集进行回归效果评价。

评价指标包括预测值和真实值的均方差(mean_loss)和预测值和真实值的相关系数(corr)

通过绘制epoch v.s. loss图以及epoch v.s. corr图,直观查看训练过程中loss和corr的变化

通过寻找最低loss的函数记录最佳的epoch_id,并保存到最佳参数目录

通过寻找最高corr的函数记录最佳的epoch_id,并保存到最佳参数目录

In [16]

#对测试数据集的预测结果进行评价batch=[]loss=[]corr=[]for batch_id in range(0,500,5):#训练轮数为500,每5轮保存一次参数    # 加载模型参数    layer_state_dict = paddle.load('checkpoint/epoch{}.pdparams'.format(batch_id))    opt_state_dict = paddle.load('checkpoint/epoch{}.pdopt'.format(batch_id))    optimizer = paddle.optimizer.SGD(learning_rate=0.001, parameters=model.parameters())    model.set_state_dict(layer_state_dict)    optimizer.set_state_dict(opt_state_dict)        # 获取预测数据    INFER_BATCH_SIZE = 100 #len(test_data)    infer_features_np = np.array([data[:13] for data in test_data]).astype("float32")    infer_labels_np = np.array([data[-1] for data in test_data]).astype("float32")    infer_features = paddle.to_tensor(infer_features_np)    infer_labels = paddle.to_tensor(infer_labels_np)    fetch_list = model(infer_features)    sum_cost = 0    for i in range(INFER_BATCH_SIZE):        infer_result = fetch_list[i][0]        ground_truth = infer_labels[i]        #if i % 10 == 0:            #print("No.%d: infer result is %.2f,ground truth is %.2f" % (i, infer_result, ground_truth))        cost = paddle.pow(infer_result - ground_truth, 2)        sum_cost += cost    mean_loss = sum_cost / INFER_BATCH_SIZE #计算均方差    x = pd.Series(np.array(fetch_list.flatten()).tolist()) #利用Series将列表转换成新的、pandas可处理的数据    y = pd.Series(infer_labels_np.tolist())    xycorr = round(x.corr(y), 4) #计算相关系数,round(a, 4)是保留a的前四位小数    print("epoch_id:%d,  Mean loss is:%.4f,  corr is:%.4f"%(batch_id, mean_loss.numpy(),xycorr))    if mean_loss.numpy()<30 :        batch=np.append(batch,batch_id)        loss=np.append(loss,mean_loss.numpy())        corr=np.append(corr,xycorr)

   In [18]

#绘制epoch v.s. loss图def plot_epoch_loss(batch, loss):    plt.figure()       plt.title("epoch v.s. loss", fontsize=24)    plt.xlabel("epoch_id", fontsize=14)    plt.ylabel("loss", fontsize=14)    plt.ylim(0,30)    plt.scatter(batch, loss, alpha=0.5)  #  scatter:散点图,alpha:"透明度"    #plt.plot(ground, ground, c='red')    plt.show()

   In [19]

#绘制epoch v.s. corr图def plot_epoch_corr(batch, corr):    plt.figure()       plt.title("epoch v.s. corr", fontsize=24)    plt.xlabel("epoch_id", fontsize=14)    plt.ylabel("corr", fontsize=14)    plt.ylim(0,1)    plt.scatter(batch, corr, alpha=0.5)  #  scatter:散点图,alpha:"透明度"    #plt.plot(ground, ground, c='red')    plt.show()

   In [20]

plot_epoch_loss(batch, loss) #绘图zuijia=int(batch[loss.tolist().index(min(loss))]) #记录最佳位置print ('loss最佳epoch位置:',zuijia)plot_epoch_corr(batch, corr) #绘图zuijia2=int(batch[corr.tolist().index(max(corr))]) #记录最佳位置print ('corr最佳epoch位置:',zuijia2)#创建用于保存最佳epoch_id的文件夹import osimport datetime# 下面列举三种格式# 年-月-日 时:分:秒nowTime=datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')# 年-月-日dayTime = datetime.datetime.now().strftime('%Y-%m-%d')# 时:分:秒hourTime = datetime.datetime.now().strftime('%H:%M:%S')# 指定文件路径file_path = 'best model{}'.format(nowTime)  # 此处也可以使用nowTime或hourTime,看你想使用哪种格式了。# 判断文件夹是否已存在isExists = os.path.exists(file_path)if not isExists:    os.makedirs(file_path )  # 若包含多级文件夹就使用makedirs,只有一个文件夹可以使用mkdirfrom shutil import copy #shutil 是用来复制黏贴文件的copy('checkpoint/epoch{}.pdparams'.format(zuijia), file_path)#完成复制黏贴copy('checkpoint/epoch{}.pdopt'.format(zuijia), file_path)#完成复制黏贴copy('checkpoint/epoch{}.pdparams'.format(zuijia2), file_path)#完成复制黏贴copy('checkpoint/epoch{}.pdopt'.format(zuijia2), file_path)#完成复制黏贴

   

7.模型应用

导入需要应用模型进行预测的数据

对导入的数据按第5部分的预处理方法进行预处理

加载模型的最佳参数,对数据进行预测,评估预测结果

把预测值和实际值进行可视化处理

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

In [21]

# 从文件导入应用数据datafile = './yingyong.data'yingyong_data = np.fromfile(datafile, sep=' ')feature_names = ['CRIM', 'ZN', 'INDUS', 'CHAS', 'NOX', 'RM', 'AGE','DIS', 'RAD', 'TAX', 'PTRATIO', 'B', 'LSTAT', 'MEDV']feature_num = len(feature_names)# 将原始数据进行Reshape,变成[N, 14]这样的形状yingyong_data = yingyong_data.reshape([yingyong_data.shape[0] // feature_num, feature_num])#!!归一化程序务必与第5部分所使用的完全一致!!只对属性进行归一化yingyong_features = feature_norm(yingyong_data[:, :13]) # print(feature_trian.shape)yingyong_data = np.c_[yingyong_features, yingyong_data[:, -1]].astype(np.float32)# print(training_data[0])

   In [22]

# load 最佳的参数batch_id=zuijia #zuijia1     !!!根据显示的epoch位置调整!!!layer_state_dict = paddle.load('best model2021-11-19 12:17:58/epoch270.pdparams')#layer_state_dict = paddle.load('checkpoint/epoch{}.pdparams'.format(batch_id))opt_state_dict = paddle.load('checkpoint/epoch{}.pdopt'.format(batch_id))model.set_state_dict(layer_state_dict)optimizer.set_state_dict(opt_state_dict)    # 获取预测数据INFER_BATCH_SIZE = len(yingyong_data)infer_features_np = np.array([data[:13] for data in yingyong_data]).astype("float32")infer_labels_np = np.array([data[-1] for data in yingyong_data]).astype("float32")infer_features = paddle.to_tensor(infer_features_np)infer_labels = paddle.to_tensor(infer_labels_np)fetch_list = model(infer_features)sum_cost = 0for i in range(INFER_BATCH_SIZE):    infer_result = fetch_list[i][0]    ground_truth = infer_labels[i]    if i % 1 == 0:        print("No.%d: infer result is %.2f,ground truth is %.2f" % (i, infer_result, ground_truth))    cost = paddle.pow(infer_result - ground_truth, 2)    sum_cost += costmean_loss = sum_cost / INFER_BATCH_SIZEprint("Mean loss is:", mean_loss.numpy())

   In [23]

x = pd.Series(np.array(fetch_list.flatten()).tolist()) #利用Series将列表转换成新的、pandas可处理的数据y = pd.Series(infer_labels_np.tolist()) xycorr = round(x.corr(y), 4) #计算标准差,round(a, 4)是保留a的前四位小数 print('相关系数 :', xycorr)

   In [24]

def plot_pred_ground(pred, ground):    plt.figure()       plt.title("Predication v.s. Ground truth"+ str(xycorr), fontsize=24)    plt.xlabel("ground truth price(unit:$1000)", fontsize=14)    plt.ylabel("predict price(unit:$1000)", fontsize=14)    plt.scatter(ground, pred, alpha=0.5)  #  scatter:散点图,alpha:"透明度"    plt.plot(ground, ground, c='red')    plt.show()plot_pred_ground(fetch_list, infer_labels_np)

   

8. 心得体会

使用此研究助手,本人对比了“在每轮迭代开始之前,将训练数据的顺序随机的打乱 np.random.shuffle(train_data)”与否的效果,进一步明白了机器学习与传统数据拟合的区别。

若对训练数据的顺序不进行随机的打乱,那么程序进行的是传统的数据拟合操作,随着程序的运行,均方差loss不断减小,说明拟合准确度在不断提高,但当加载模型及参数对测试集进行预测时,看到预测集中loss很大,且变化幅度很大。

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟 基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

若对训练数据的顺序进行随机的打乱,那么程序进行的是机器学习过程,随着程序的运行,均方差loss呈现波动下降趋势,这是因为每一次打乱顺序都会对loss造成脉冲,但经优化后loss仍会逐步下降。当加载模型及参数对测试集进行预测时,看到预测集中loss很小,且存在变化不大的区间。

基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟 基于PaddlePaddle2.2的数据建模研究助手 - 创想鸟        

以上就是基于PaddlePaddle2.2的数据建模研究助手的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/737057.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 13:25:38
下一篇 2025年11月25日 13:31:24

相关推荐

  • Uniapp 中如何不拉伸不裁剪地展示图片?

    灵活展示图片:如何不拉伸不裁剪 在界面设计中,常常需要以原尺寸展示用户上传的图片。本文将介绍一种在 uniapp 框架中实现该功能的简单方法。 对于不同尺寸的图片,可以采用以下处理方式: 极端宽高比:撑满屏幕宽度或高度,再等比缩放居中。非极端宽高比:居中显示,若能撑满则撑满。 然而,如果需要不拉伸不…

    2025年12月24日
    400
  • 如何让小说网站控制台显示乱码,同时网页内容正常显示?

    如何在不影响用户界面的情况下实现控制台乱码? 当在小说网站上下载小说时,大家可能会遇到一个问题:网站上的文本在网页内正常显示,但是在控制台中却是乱码。如何实现此类操作,从而在不影响用户界面(UI)的情况下保持控制台乱码呢? 答案在于使用自定义字体。网站可以通过在服务器端配置自定义字体,并通过在客户端…

    2025年12月24日
    800
  • 如何在地图上轻松创建气泡信息框?

    地图上气泡信息框的巧妙生成 地图上气泡信息框是一种常用的交互功能,它简便易用,能够为用户提供额外信息。本文将探讨如何借助地图库的功能轻松创建这一功能。 利用地图库的原生功能 大多数地图库,如高德地图,都提供了现成的信息窗体和右键菜单功能。这些功能可以通过以下途径实现: 高德地图 JS API 参考文…

    2025年12月24日
    400
  • 如何使用 scroll-behavior 属性实现元素scrollLeft变化时的平滑动画?

    如何实现元素scrollleft变化时的平滑动画效果? 在许多网页应用中,滚动容器的水平滚动条(scrollleft)需要频繁使用。为了让滚动动作更加自然,你希望给scrollleft的变化添加动画效果。 解决方案:scroll-behavior 属性 要实现scrollleft变化时的平滑动画效果…

    2025年12月24日
    000
  • 如何为滚动元素添加平滑过渡,使滚动条滑动时更自然流畅?

    给滚动元素平滑过渡 如何在滚动条属性(scrollleft)发生改变时为元素添加平滑的过渡效果? 解决方案:scroll-behavior 属性 为滚动容器设置 scroll-behavior 属性可以实现平滑滚动。 html 代码: click the button to slide right!…

    2025年12月24日
    500
  • 如何选择元素个数不固定的指定类名子元素?

    灵活选择元素个数不固定的指定类名子元素 在网页布局中,有时需要选择特定类名的子元素,但这些元素的数量并不固定。例如,下面这段 html 代码中,activebar 和 item 元素的数量均不固定: *n *n 如果需要选择第一个 item元素,可以使用 css 选择器 :nth-child()。该…

    2025年12月24日
    200
  • 使用 SVG 如何实现自定义宽度、间距和半径的虚线边框?

    使用 svg 实现自定义虚线边框 如何实现一个具有自定义宽度、间距和半径的虚线边框是一个常见的前端开发问题。传统的解决方案通常涉及使用 border-image 引入切片图片,但是这种方法存在引入外部资源、性能低下的缺点。 为了避免上述问题,可以使用 svg(可缩放矢量图形)来创建纯代码实现。一种方…

    2025年12月24日
    100
  • 旋转长方形后,如何计算其相对于画布左上角的轴距?

    绘制长方形并旋转,计算旋转后轴距 在拥有 1920×1080 画布中,放置一个宽高为 200×20 的长方形,其坐标位于 (100, 100)。当以任意角度旋转长方形时,如何计算它相对于画布左上角的 x、y 轴距? 以下代码提供了一个计算旋转后长方形轴距的解决方案: const x = 200;co…

    2025年12月24日
    000
  • 旋转长方形后,如何计算它与画布左上角的xy轴距?

    旋转后长方形在画布上的xy轴距计算 在画布中添加一个长方形,并将其旋转任意角度,如何计算旋转后的长方形与画布左上角之间的xy轴距? 问题分解: 要计算旋转后长方形的xy轴距,需要考虑旋转对长方形宽高和位置的影响。首先,旋转会改变长方形的长和宽,其次,旋转会改变长方形的中心点位置。 求解方法: 计算旋…

    2025年12月24日
    000
  • 旋转长方形后如何计算其在画布上的轴距?

    旋转长方形后计算轴距 假设长方形的宽、高分别为 200 和 20,初始坐标为 (100, 100),我们将它旋转一个任意角度。根据旋转矩阵公式,旋转后的新坐标 (x’, y’) 可以通过以下公式计算: x’ = x * cos(θ) – y * sin(θ)y’ = x * …

    2025年12月24日
    000
  • 如何让“元素跟随文本高度,而不是撑高父容器?

    如何让 元素跟随文本高度,而不是撑高父容器 在页面布局中,经常遇到父容器高度被子元素撑开的问题。在图例所示的案例中,父容器被较高的图片撑开,而文本的高度没有被考虑。本问答将提供纯css解决方案,让图片跟随文本高度,确保父容器的高度不会被图片影响。 解决方法 为了解决这个问题,需要将图片从文档流中脱离…

    2025年12月24日
    000
  • 如何计算旋转后长方形在画布上的轴距?

    旋转后长方形与画布轴距计算 在给定的画布中,有一个长方形,在随机旋转一定角度后,如何计算其在画布上的轴距,即距离左上角的距离? 以下提供一种计算长方形相对于画布左上角的新轴距的方法: const x = 200; // 初始 x 坐标const y = 90; // 初始 y 坐标const w =…

    2025年12月24日
    200
  • CSS元素设置em和transition后,为何载入页面无放大效果?

    css元素设置em和transition后,为何载入无放大效果 很多开发者在设置了em和transition后,却发现元素载入页面时无放大效果。本文将解答这一问题。 原问题:在视频演示中,将元素设置如下,载入页面会有放大效果。然而,在个人尝试中,并未出现该效果。这是由于macos和windows系统…

    2025年12月24日
    200
  • 为什么 CSS mask 属性未请求指定图片?

    解决 css mask 属性未请求图片的问题 在使用 css mask 属性时,指定了图片地址,但网络面板显示未请求获取该图片,这可能是由于浏览器兼容性问题造成的。 问题 如下代码所示: 立即学习“前端免费学习笔记(深入)”; icon [data-icon=”cloud”] { –icon-cl…

    2025年12月24日
    200
  • 如何利用 CSS 选中激活标签并影响相邻元素的样式?

    如何利用 css 选中激活标签并影响相邻元素? 为了实现激活标签影响相邻元素的样式需求,可以通过 :has 选择器来实现。以下是如何具体操作: 对于激活标签相邻后的元素,可以在 css 中使用以下代码进行设置: li:has(+li.active) { border-radius: 0 0 10px…

    2025年12月24日
    100
  • 如何模拟Windows 10 设置界面中的鼠标悬浮放大效果?

    win10设置界面的鼠标移动显示周边的样式(探照灯效果)的实现方式 在windows设置界面的鼠标悬浮效果中,光标周围会显示一个放大区域。在前端开发中,可以通过多种方式实现类似的效果。 使用css 使用css的transform和box-shadow属性。通过将transform: scale(1.…

    2025年12月24日
    200
  • 如何计算旋转后的长方形在画布上的 XY 轴距?

    旋转长方形后计算其画布xy轴距 在创建的画布上添加了一个长方形,并提供其宽、高和初始坐标。为了视觉化旋转效果,还提供了一些旋转特定角度后的图片。 问题是如何计算任意角度旋转后,这个长方形的xy轴距。这涉及到使用三角学来计算旋转后的坐标。 以下是一个 javascript 代码示例,用于计算旋转后长方…

    2025年12月24日
    000
  • 为什么我的 Safari 自定义样式表在百度页面上失效了?

    为什么在 Safari 中自定义样式表未能正常工作? 在 Safari 的偏好设置中设置自定义样式表后,您对其进行测试却发现效果不同。在您自己的网页中,样式有效,而在百度页面中却失效。 造成这种情况的原因是,第一个访问的项目使用了文件协议,可以访问本地目录中的图片文件。而第二个访问的百度使用了 ht…

    2025年12月24日
    000
  • 如何用前端实现 Windows 10 设置界面的鼠标移动探照灯效果?

    如何在前端实现 Windows 10 设置界面中的鼠标移动探照灯效果 想要在前端开发中实现 Windows 10 设置界面中类似的鼠标移动探照灯效果,可以通过以下途径: CSS 解决方案 DEMO 1: Windows 10 网格悬停效果:https://codepen.io/tr4553r7/pe…

    2025年12月24日
    000
  • 使用CSS mask属性指定图片URL时,为什么浏览器无法加载图片?

    css mask属性未能加载图片的解决方法 使用css mask属性指定图片url时,如示例中所示: mask: url(“https://api.iconify.design/mdi:apple-icloud.svg”) center / contain no-repeat; 但是,在网络面板中却…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信