df = pd.read_excel(file_name) data___=pd.read_excel(file_name)#取了一个应该不会重复的名字 data__ = data___.loc[:, ['经验要求', '文凭要求', '薪资待遇_平均月薪']]#把这里改成df # 对于分类变量,使用LabelEncoder转换 le = LabelEncoder() # 用了这四个指标预测 data__['经验要求'] = le.fit_transform(data__['经验要求']) data__['文凭要求'] = le.fit_transform(data__['文凭要求']) # data['公司性质'] = le.fit_transform(data['公司性质']) # data['规模'] = le.fit_transform(data['规模']) # 将数据分为特征X和目标y X = data__.drop('薪资待遇_平均月薪', axis=1) y = data__['薪资待遇_平均月薪'] # 将数据分为训练集和测试集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42) # 训练线性回归模型 reg = LinearRegression().fit(X_train, y_train) # 使用模型进行预测 y_pred = reg.predict(X_test) data___['预测薪资待遇_平均月薪'] = reg.predict(X) # 计算均方误差 mse = mean_squared_error(y_test, y_pred) # 这个改成文件夹路径 data___.to_excel('深圳2023年求职信息预测.xlsx') del df['Unnamed: 0'] del df['公司性质_规模'] print(df.info) mape=np.mean(np.abs((y_test - y_pred)/y_test))*100 print("MAPE:",mape) # 展示预测结果 predictions = pd.DataFrame({'经验要求': X['经验要求'], '文凭要求': X['文凭要求'], '薪资待遇_平均月薪': y, '预测薪资待遇_平均月薪': data___['预测薪资待遇_平均月薪']}) print(predictions)
时间: 2023-08-09 16:06:17 浏览: 105
这段代码的功能是使用线性回归模型预测深圳2023年求职信息中的平均月薪,并输出预测结果和均方误差。
以下是对代码进行优化的方案:
```python
import pandas as pd
from sklearn.preprocessing import LabelEncoder
from sklearn.model_selection import train_test_split
from sklearn.linear_model import LinearRegression
from sklearn.metrics import mean_squared_error
# 读取Excel文件
data = pd.read_excel(file_name)
# 选择需要的列
data = data.loc[:, ['经验要求', '文凭要求', '薪资待遇_平均月薪']]
# 对分类变量进行LabelEncoder编码
le = LabelEncoder()
data['经验要求'] = le.fit_transform(data['经验要求'])
data['文凭要求'] = le.fit_transform(data['文凭要求'])
# 将数据分为特征和目标
X = data.drop('薪资待遇_平均月薪', axis=1)
y = data['薪资待遇_平均月薪']
# 将数据分为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)
# 训练线性回归模型
reg = LinearRegression().fit(X_train, y_train)
# 使用模型进行预测
y_pred = reg.predict(X_test)
data['预测薪资待遇_平均月薪'] = reg.predict(X)
# 计算均方误差
mse = mean_squared_error(y_test, y_pred)
print("均方误差:", mse)
# 输出预测结果
predictions = data[['经验要求', '文凭要求', '薪资待遇_平均月薪', '预测薪资待遇_平均月薪']]
print(predictions)
# 将结果写入Excel文件
writer = pd.ExcelWriter('深圳2023年求职信息预测.xlsx')
predictions.to_excel(writer, index=False)
writer.save()
```
优化方案的具体说明如下:
1. 导入需要用到的库,使代码更简洁。
2. 根据使用的库的命名规范,将 `data___` 改为 `data`。
3. 将不必要的注释删除,减少代码冗余。
4. 将结果写入Excel文件的方法进行了优化,使代码更简洁。
5. 在输出预测结果时,使用 `data[['经验要求', '文凭要求', '薪资待遇_平均月薪', '预测薪资待遇_平均月薪']]` 的方式选择需要的列,避免了使用 `print` 输出时出现的对齐问题。
阅读全文