」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 Scikit-learn 預測房價:完整指南

使用 Scikit-learn 預測房價:完整指南

發佈於2024-11-02
瀏覽:409

Predicting House Prices with Scikit-learn: A Complete Guide

机器学习正在改变各个行业,包括房地产。一项常见的任务是根据卧室、浴室的数量、平方英尺和位置等各种特征来预测房价。在本文中,我们将探讨如何使用scikit-learn构建机器学习模型来预测房价,涵盖从数据预处理到模型部署的各个方面。

目录

  1. Scikit-learn 简介
  2. 问题定义
  3. 数据收集
  4. 数据预处理
  5. 特征选择
  6. 模型训练
  7. 模型评估
  8. 模型调优(超参数优化)
  9. 模型部署
  10. 结论

1.Scikit-learn简介

Scikit-learn 是 Python 中使用最广泛的机器学习库之一。它为数据分析和建模提供了简单高效的工具。无论您是处理分类、回归、聚类还是降维,scikit-learn 都提供了一组广泛的实用程序来帮助您构建强大的机器学习模型。

在本指南中,我们将使用 scikit-learn 构建回归模型来预测房价。让我们逐步了解该过程的每个步骤。


2. 问题定义

手头的任务是根据房屋的特征来预测其价格,例如:

  • 卧室数量
  • 浴室数量
  • 面积(平方英尺)
  • 地点

这是一个监督学习问题,其中目标变量(房价)是连续的,使其成为回归任务。 Scikit-learn 提供了多种回归算法,例如我们将在本项目中使用的线性回归随机森林


3. 数据收集

您可以使用真实世界的数据集(例如 Kaggle 房价数据集),也可以从公共 API 收集您自己的数据。

以下是您的数据的示例:

卧室 浴室 面积(平方英尺) 地点 价格 ($)
3 2 1500 波士顿 300,000
4 3 2000年 西雅图 500,000

这里的目标变量是价格.


4. 数据预处理

在将数据输入机器学习模型之前,我们需要对其进行预处理。这包括处理缺失值、编码分类特征以及缩放数据。

处理缺失数据

缺失数据在现实世界的数据集中很常见。我们可以使用中位数等统计度量来填充缺失值,也可以删除包含缺失数据的行:

data.fillna(data.median(), inplace=True)

编码分类特征

由于机器学习模型需要数字输入,因此我们需要将位置等分类特征转换为数字。 标签编码为每个类别分配一个唯一的编号:

from sklearn.preprocessing import LabelEncoder
encoder = LabelEncoder()
data['Location'] = encoder.fit_transform(data['Location'])

特征缩放

缩放面积和价格等特征以确保它们处于相同的比例非常重要,特别是对于对特征大小敏感的算法。以下是我们如何应用缩放:

from sklearn.preprocessing import StandardScaler
scaler = StandardScaler()
X_scaled = scaler.fit_transform(X)

5. 特征选择

并非所有特征对目标变量的贡献均等。特征选择有助于识别最重要的特征,从而提高模型性能并减少过度拟合。

在这个项目中,我们使用SelectKBest根据与目标变量的相关性来选择前5个特征:

from sklearn.feature_selection import SelectKBest, f_regression
selector = SelectKBest(score_func=f_regression, k=5)
X_new = selector.fit_transform(X, y)

6. 模型训练

现在我们已经预处理了数据并选择了最佳特征,是时候训练模型了。我们将使用两种回归算法:线性回归随机森林

线性回归

线性回归拟合数据的直线,最小化预测值和实际值之间的差异:

from sklearn.linear_model import LinearRegression
linear_model = LinearRegression()
linear_model.fit(X_train, y_train)

随机森林

随机森林是一种集成方法,它使用多个决策树并对它们的结果进行平均,以提高准确性并减少过度拟合:

from sklearn.ensemble import RandomForestRegressor
forest_model = RandomForestRegressor(n_estimators=100)
forest_model.fit(X_train, y_train)

训练-测试分离

为了评估我们的模型的泛化能力,我们将数据分为训练集和测试集:

from sklearn.model_selection import train_test_split
X_train, X_test, y_train, y_test = train_test_split(X_new, y, test_size=0.2, random_state=42)

7. 模型评估

训练模型后,我们需要使用 均方误差 (MSE)R 平方 (R²) 等指标来评估其性能。

均方误差 (MSE)

MSE 计算预测值和实际值之间的平均平方差。 MSE 越低表示性能越好:

from sklearn.metrics import mean_squared_error
mse = mean_squared_error(y_test, y_pred)

R 平方 (R²)

R² 告诉我们模型解释目标变量方差的程度。值为 1 表示完美预测:

from sklearn.metrics import r2_score
r2 = r2_score(y_test, y_pred)

使用这些指标比较线性回归和随机森林模型的性能。


8.模型调优(超参数优化)

为了进一步提高模型性能,我们可以对超参数进行微调。对于随机森林,像 n_estimators(树的数量)和 max_depth(树的最大深度)这样的超参数会显着影响性能。

以下是如何使用GridSearchCV进行超参数优化:

from sklearn.model_selection import GridSearchCV

param_grid = {
    'n_estimators': [50, 100, 200],
    'max_depth': [None, 10, 20]
}

grid_search = GridSearchCV(RandomForestRegressor(), param_grid, cv=5)
grid_search.fit(X_train, y_train)

best_model = grid_search.best_estimator_

9. 模型部署

训练并调整模型后,下一步就是部署。您可以使用 Flask 创建一个提供预测服务的简单 Web 应用程序。

这是一个用于房价预测的基本 Flask 应用程序:

from flask import Flask, request, jsonify
import joblib

app = Flask(__name__)

# Load the trained model
model = joblib.load('best_model.pkl')

@app.route('/predict', methods=['POST'])
def predict():
    data = request.json
    prediction = model.predict([data['features']])
    return jsonify({'predicted_price': prediction[0]})

if __name__ == '__main__':
    app.run()

使用joblib:
保存训练好的模型

import joblib
joblib.dump(best_model, 'best_model.pkl')

这样,您就可以通过向 API 发送请求来进行预测。


10. 结论

在这个项目中,我们探索了使用 scikit-learn 构建机器学习模型来预测房价的整个过程。从数据预处理、特征选择到模型训练、评估、部署,每一步都配有实用的代码示例。

无论您是机器学习新手还是希望在实际项目中应用 scikit-learn,本指南都提供了一个全面的工作流程,您可以根据它来适应各种回归任务。

随意尝试不同的模型、数据集和技术,以提高模型的性能和准确性。

回归 #AI #DataAnalysis #DataPreprocessing #MLModel #RandomForest #LinearRegression #Flask #APIDevelopment #RealEstate #TechBlog #Tutorial #DataEngineering #DeepLearning #PredictiveAnalytics #DevCommunity

版本聲明 本文轉載於:https://dev.to/amitchandra/predicting-house-prices-with-scikit-learn-a-complete-guide-2kd7?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在C#中如何高效重複字符串字符用於縮進?
    在C#中如何高效重複字符串字符用於縮進?
    在基於項目的深度下固定字符串時,重複一個字符串以進行凹痕,很方便有效地有一種有效的方法來返回字符串重複指定的次數的字符串。使用指定的次數。 constructor 這將返回字符串“ -----”。 字符串凹痕= new String(' - ',depth); console.W...
    程式設計 發佈於2025-07-01
  • 如何干淨地刪除匿名JavaScript事件處理程序?
    如何干淨地刪除匿名JavaScript事件處理程序?
    刪除匿名事件偵聽器將匿名事件偵聽器添加到元素中會提供靈活性和簡單性,但是當需要刪除它們時,可以構成挑戰,而無需替換元素本身就可以替換一個問題。 element? element.addeventlistener(event,function(){/在這里工作/},false); 要解決此問題,請...
    程式設計 發佈於2025-07-01
  • 如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    如何從PHP中的Unicode字符串中有效地產生對URL友好的sl。
    為有效的slug生成首先,該函數用指定的分隔符替換所有非字母或數字字符。此步驟可確保slug遵守URL慣例。隨後,它採用ICONV函數將文本簡化為us-ascii兼容格式,從而允許更廣泛的字符集合兼容性。 接下來,該函數使用正則表達式刪除了不需要的字符,例如特殊字符和空格。此步驟可確保slug僅包...
    程式設計 發佈於2025-07-01
  • 對象擬合:IE和Edge中的封面失敗,如何修復?
    對象擬合:IE和Edge中的封面失敗,如何修復?
    To resolve this issue, we employ a clever CSS solution that solves the problem:position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%)...
    程式設計 發佈於2025-07-01
  • eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    eval()vs. ast.literal_eval():對於用戶輸入,哪個Python函數更安全?
    稱量()和ast.literal_eval()中的Python Security 在使用用戶輸入時,必須優先確保安全性。強大的Python功能Eval()通常是作為潛在解決方案而出現的,但擔心其潛在風險。本文深入研究了eval()和ast.literal_eval()之間的差異,突出顯示其安全性含義...
    程式設計 發佈於2025-07-01
  • Python讀取CSV文件UnicodeDecodeError終極解決方法
    Python讀取CSV文件UnicodeDecodeError終極解決方法
    在試圖使用已內置的CSV模塊讀取Python中時,CSV文件中的Unicode Decode Decode Decode Decode decode Error讀取,您可能會遇到錯誤的錯誤:無法解碼字節 在位置2-3中:截斷\ uxxxxxxxx逃脫當CSV文件包含特殊字符或Unicode的路徑逃...
    程式設計 發佈於2025-07-01
  • 如何使用替換指令在GO MOD中解析模塊路徑差異?
    如何使用替換指令在GO MOD中解析模塊路徑差異?
    在使用GO MOD時,在GO MOD 中克服模塊路徑差異時,可能會遇到衝突,其中3個Party Package將另一個PAXPANCE帶有導入式套件之間的另一個軟件包,並在導入式套件之間導入另一個軟件包。如迴聲消息所證明的那樣: go.etcd.io/bbolt [&&&&&&&&&&&&&&&&...
    程式設計 發佈於2025-07-01
  • 如何實時捕獲和流媒體以進行聊天機器人命令執行?
    如何實時捕獲和流媒體以進行聊天機器人命令執行?
    在開發能夠執行命令的chatbots的領域中,實時從命令執行實時捕獲Stdout,一個常見的需求是能夠檢索和顯示標準輸出(stdout)在cath cath cant cant cant cant cant cant cant cant interfaces in Chate cant inter...
    程式設計 發佈於2025-07-01
  • FastAPI自定義404頁面創建指南
    FastAPI自定義404頁面創建指南
    response = await call_next(request) if response.status_code == 404: return RedirectResponse("https://fastapi.tiangolo.com") else: ...
    程式設計 發佈於2025-07-01
  • 圖片在Chrome中為何仍有邊框? `border: none;`無效解決方案
    圖片在Chrome中為何仍有邊框? `border: none;`無效解決方案
    在chrome 在使用Chrome and IE9中的圖像時遇到的一個頻繁的問題是圍繞圖像的持續薄薄邊框,儘管指定了圖像,儘管指定了;和“邊境:無;”在CSS中。要解決此問題,請考慮以下方法: Chrome具有忽略“ border:none; none;”的已知錯誤,風格。要解決此問題,請使用以下...
    程式設計 發佈於2025-07-01
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP將...
    程式設計 發佈於2025-07-01
  • 如何使用“ JSON”軟件包解析JSON陣列?
    如何使用“ JSON”軟件包解析JSON陣列?
    parsing JSON與JSON軟件包 QUALDALS:考慮以下go代碼:字符串 } func main(){ datajson:=`[“ 1”,“ 2”,“ 3”]`` arr:= jsontype {} 摘要:= = json.unmarshal([] byte(...
    程式設計 發佈於2025-07-01
  • 如何使用不同數量列的聯合數據庫表?
    如何使用不同數量列的聯合數據庫表?
    合併列數不同的表 當嘗試合併列數不同的數據庫表時,可能會遇到挑戰。一種直接的方法是在列數較少的表中,為缺失的列追加空值。 例如,考慮兩個表,表 A 和表 B,其中表 A 的列數多於表 B。為了合併這些表,同時處理表 B 中缺失的列,請按照以下步驟操作: 確定表 B 中缺失的列,並將它們添加到表的...
    程式設計 發佈於2025-07-01
  • 如何在鼠標單擊時編程選擇DIV中的所有文本?
    如何在鼠標單擊時編程選擇DIV中的所有文本?
    在鼠標上選擇div文本單擊帶有文本內容,用戶如何使用單個鼠標單擊單擊div中的整個文本?這允許用戶輕鬆拖放所選的文本或直接複製它。 在單個鼠標上單擊的div元素中選擇文本,您可以使用以下Javascript函數: function selecttext(canduterid){ if(d...
    程式設計 發佈於2025-07-01
  • 編譯器報錯“usr/bin/ld: cannot find -l”解決方法
    編譯器報錯“usr/bin/ld: cannot find -l”解決方法
    錯誤:“ usr/bin/ld:找不到-l “ 此錯誤表明鏈接器在鏈接您的可執行文件時無法找到指定的庫。為了解決此問題,我們將深入研究如何指定庫路徑並將鏈接引導到正確位置的詳細信息。 添加庫搜索路徑的一個可能的原因是,此錯誤是您的makefile中缺少庫搜索路徑。要解決它,您可以在鏈接器命令中添...
    程式設計 發佈於2025-07-01

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3