数据清洗到站点聚类,全面解析伦敦共享单车使用规律!
文章正文
发布时间:2024-08-29 00:43
随着共享单车在全球范围内的普及,地毯清洗13825404095城市交通出行模式发生了巨大变化。伦敦作为国际化大都市,交通拥堵问题日益严重,共享单车作为一种绿色、环保、便捷的出行方式,逐渐成为解决交通问题的重要组成部分,然而,要实现共享单车系统的高效运营,必须深入了解用户的使用习惯和需求。本项目对伦敦共享单车数据进行了全面分析,涵盖了数据清洗、特征工程(构建新特征)、骑行高峰期分析、站点流量分析,以及通过聚类分析将800个站点划分为5类,并对每一类站点提出建议,最后通过方差分析探讨了影响共享单车流量的因素,通过这些步骤,可以识别高频使用的时间段和站点,为运营商提供优化调度和资源分配的科学依据。
2.数据说明
字段
说明
Number
每次出行的唯一标识符(Trip ID)
Start Date
出行开始的日期和时间
Start Station Number
起始站的标识符
Start Station
起始站的名称
End Date
出行结束的日期和时间
End Station Number
终点站的标识符
End Station
终点站的名称
Bike Number
所使用自行车的唯一标识符
Bike Model
所使用自行车的型号
Total Duration
出行的总时间(时分秒)
Total Duration (ms)
出行的总时间(毫秒)
3.Python库导入及数据读取
import pandas
as pd
import seaborn
as sns
import matplotlib
.pyplot
as plt
import networkx
as nx
import matplotlib
.colors
as mcolors
import numpy
as np
from sklearn
.cluster
import KMeans
from sklearn
.preprocessing
import StandardScaler
from sklearn
.decomposition
import PCA
from sklearn
.metrics
import silhouette_score
import scipy
.stats
as stats
import warnings
warnings
.filterwarnings
('ignore')
from pylab
import mpl
mpl
.rcParams
["font.sans-serif"] = ["SimHei"] # 设置显示中文字体 宋体
mpl
.rcParams
["axes.unicode_minus"] = False #字体更改后,会导致坐标轴中的部分字符无法正常显示,此时需要设置正常显示负号
data
= pd
.read_csv
('D:\Desktop\商业数据分析案例\伦敦共享单车数据集\LondonBikeJourneyAug2023.csv')
4.数据预览及数据处理
# 查看数据维度
data
.shape
(776527, 11)
#查看数据信息
data
.info
()
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 776527 entries, 0 to 776526
Data columns (total 11 columns):
# Column
Non-Null Count Dtype
--- ------
-------------- -----
0 Number
776527 non-null int64
1 Start date
776527 non-null object
2 Start station number 776527 non-null int64
3 Start station
776527 non-null object
4 End date
776527 non-null object
5 End station number 776527 non-null int64
6 End station
776527 non-null object
7 Bike number
776527 non-null int64
8 Bike model
776527 non-null object
9 Total duration
776527 non-null object
10 Total duration (ms) 776527 non-null int64
dtypes: int64(5), object(6)
memory usage: 65.2+ MB
#查看各列缺失值
data
.isna
().sum()
Number
0
Start date
0
Start station number 0
Start station
0
End date
0
End station number
0
End station
0
Bike number
0
Bike model
0
Total duration
0
Total duration (ms)
0
dtype: int64
#查看重复值
data
.duplicated
().sum()
0
# 将起始日期和结束日期转换为日期时间格式
data
[