文档

预处理和探索时间戳数据使用时间表

此示例显示了如何使用时间表用于组织和预处理时间戳数据的数据容器。数据来自马萨诸塞州剑桥市百老汇街的传感器。剑桥市为公众提供在剑桥大学公开数据网站。

这个示例展示了如何执行各种数据清理、删除和预处理任务,例如删除丢失的值和使用不同的时间步骤同步带有时间戳的数据。此外,突出显示了数据探索,包括可视化和使用时间表数据容器到:

  • 了解每天的自行车流量

  • 将自行车交通与当地天气条件进行比较

  • 分析一周中不同时间的自行车交通量

导入自行车交通数据到时间表

从逗号分隔的文本文件导入自行车交通数据示例。的可读函数返回表中的数据功能。

bikeTbl=可读(“bicyclecoounts.csv”); 头部(比克特布尔)
ans =8×5表Timestamp Day Total Westbound Eastbound ___________________ ________________ __________________ 2015-06-24 00:00:00 'Wednesday' 13 9 4 2015-06-24 01:00:00 'Wednesday' 3 3 0 2015-06-24 02:00:00 'Wednesday' 1 1 0 2015-06-24 03:00:00 'Wednesday' 1 1 0 2015-06-24 05:00:00 'Wednesday' 7 3 4 2015-06-24 06:00:00'星期三' 36 6 30 2015-06-24 07:00:00 '星期三' 141 13 128

数据有时间戳,因此使用时间表来存储和分析数据是很方便的。时间表类似于表,但包含与数据行相关联的时间戳。时间戳或行时间用datetime期间值。datetime期间分别为表示时间点或运行时间的推荐数据类型。

转换bikeTbl变成一个时间表table2timetable函数。必须使用转换函数,因为可读返回一个表。table2timetable将第一个datetime期间将表中的变量转换为时间表的行时间。行时间是标记行的元数据。但是,当您显示时间表时,行时间和时间表变量将以类似的方式显示。请注意,表有五个变量,而时间表有四个。

bikeData=表2可计量(bikeTbl);头部(比克达塔)
ans =8×4时间表Timestamp Day Total Westbound Eastbound ___________________ ________________ __________________ 2015-06-24 00:00:00 'Wednesday' 13 9 4 2015-06-24 01:00:00 'Wednesday' 3 3 0 2015-06-24 02:00:00 'Wednesday' 1 1 0 2015-06-24 03:00:00 'Wednesday' 1 1 0 2015-06-24 05:00:00 'Wednesday' 7 3 4 2015-06-24 06:00:00'星期三' 36 6 30 2015-06-24 07:00:00 '星期三' 141 13 128
bikeTblbikeData
名称大小字节类属性bikeData 9387x4 1487450时刻表bikeTbl 9387x5 1562776 table

访问时间和数据

转换一天变量来分类。分类数据类型是为包含有限离散值集的数据而设计的,比如星期几的名称。列出类别,以便按日顺序显示。使用点下标按名称访问变量。

bikeData.Day=分类(bikeData.Day{“星期天”“周一”“星期二”...“星期三”“星期四”“星期五”“星期六”});

在时间表中,时间与数据变量分开处理属性表的第一个维度是行时间,第二个维度是变量。的DimensionNames属性显示两个维度的名称,而VariableNames属性显示沿第2维的变量的名称。

bikeData。属性
ans=带字段的结构:描述:" UserData: [] DimensionNames: {'Timestamp' 'Variables'} VariableNames: {'Day' 'Total' 'Westbound' 'Eastbound'} variabledescription: {} VariableUnits: {} variablecontinuityity: [] RowTimes: [9387x1 datetime]

默认情况下,table2timetable分配时间戳作为将表转换为时间表时的第一个维度名称,因为这是原始表中的变量名称。您可以通过更改维度的名称和其他时间表元数据属性

将尺寸标注的名称更改为时间资料

bikeData.Properties.DimensionNames = {“时间”“数据”};比克达酒店
ans=带字段的结构:描述:" UserData: [] DimensionNames: {'Time' 'Data'} VariableNames: {'Day' 'Total' '' Westbound' 'Eastbound'} variabledescription: {} VariableUnits: {} variablecontinuityity: [] RowTimes: [9387x1 datetime]

显示时间表的前八行。

头(bikeData)
ans =8×4时间表时间一天总西行的往东的  ___________________ _________ _____ _________ _________ 2015-06-24就是星期三13 9 4 2015-06-24 01:00:00周三3 3 0 2015-06-24 02:00:00周三1 1 0 2015-06-24 03:00:00周三1 1 0 2015-06-24 04:00:00周三1 1 0 2015-06-24 05:00:00周三7 3 4 2015-06-24 06:00:00周三36 6 302015-06-24 07:00:00星期三141 13 128

确定最近的行时间和最早的行时间之间经过的天数。当一次引用一个变量时,变量可以通过点表示法访问。

elapsedTime = max(bikeData.Time) - min(bikeData.Time)
拖延时间=期间9383:30:00
elapsedTime.Format=' d '
拖延时间=期间390.98天

为了检查某一天典型的自行车数量,计算自行车总数的平均值,以及西行和东行的数量。

的内容建立索引,以矩阵形式返回数值数据bikeData使用大括号。显示前八行。使用标准表订阅访问多个变量。

计数=bikeData{,2:end};计数(1:8,:)
ans=8×313 9 4 3 30 1 1 0 1 1 0 1 1 0 7 3 4 36 6 30 141 13 128

由于均值仅适用于数字数据,因此可以使用变形金刚函数选择数值变量。变形金刚可以比手动索引到表或时间表更方便地选择变量。计算平均值并省略值。

计数=bikeData{:,vartype(“数字”)};意思是(计数,“omitnan”
ans=1×349.8860 24.2002 25.6857

按日期和时间选择数据

要确定假期中有多少人骑自行车,请查看7月4日假期的数据。2015年7月4日按行时间索引到时间表中。在对行时间进行索引时,必须精确匹配时间。您可以将时间索引指定为datetime期间值,或可转换为日期和时间的字符向量。您可以将多次指定为一个数组。

索引bikeData以具体日期和时间提取2015年7月4日的数据。如果仅指定日期,则假定时间为午夜或00:00:00。

bikeData (“2015-07-04”:)
ans =1×4时间表时间一天总西行的往东的  ___________________ ________ _____ _________ _________ 2015-07-04就是周六8 7 1
d = {'2015-07-04 08:00:00'“2015-07-04 09:00:00”};bikeData (d,:)
ans =2×4时间表时间一天总西行的往东的  ___________________ ________ _____ _________ _________ 2015-07-04 08:00:00周六15 3 12 2015-07-04 09:00:00周六21 4 17

用这种方法提取一整天的时间是很乏味的。您还可以指定时间范围,而无需对特定时间进行索引。要创建时间段下标作为helper,请使用timerange功能。

使用2015年7月4日全天的时间范围下标到时间表中。设置开始时间为7月4日午夜,结束时间为7月5日午夜。默认情况下,timerange包括从开始时间到结束时间(但不包括结束时间)的所有时间。在地图上标出一天中自行车的数量。

tr = timerange (“2015-07-04”“2015-07-05”);jul4 = bikeData (tr,“总计”);负责人(7月4日)
ans =8×1的时间表时间总计___________________ _____ 2015-07-04 00:00:00 8 2015-07-04 01:00:00 13 2015-07-04 02:00:00 4 2015-07-04 03:00:00 1 2015-07-04 04:00:00 0 2015-07-04 05:00:00 1 2015-07-04 06:00:00 8 2015-07-04 07:00:00
酒吧(jul4.Time jul4.Total) ylabel (“自行车计数”)头衔(“2015年7月4日自行车计数”

从图中可以看出,全天的业务量都在增加,下午趋于平稳。因为很多商店都关门了,所以这个地块没有显示通勤时间的典型交通状况。晚上晚些时候的峰值可以归因于在天黑后燃放烟花的庆祝活动。为了更仔细地检查这些趋势,应该将数据与典型天数的数据进行比较。

将7月4日的数据与7月其余时间的数据进行比较。

7月= bikeData (timerange ('2015-07-01'“2015-08-01”),:;绘图(七月时间,七月总计)保持情节(jul4.Time jul4.Total) ylabel (“总数”)头衔(“七月自行车数”)举行传奇(“自行车计数”“7月4日自行车计数”

图表显示了工作日和周末之间的交通差异。7月4日和5日的交通情况与周末的交通情况一致。7月5日是星期一,但通常是假日。这些趋势可以通过进一步的预处理和分析来更仔细地检查。

预处理时间和数据使用时间表

带有时间戳的数据集通常是杂乱的,可能包含异常或错误。时间表非常适合解决异常和错误。

时间表不必以任何特定的顺序列出行时间。它可以包含不按行时间排序的行。时间表也可以包含具有相同行时间的多行,尽管这些行可以具有不同的数据值。即使行时间已排序且唯一,它们也可能因大小不同的时间步长而不同。时间表甚至可以包含纳特值指示缺失行时间。

时间表数据类型提供了许多不同的方法来解决丢失、重复或不一致的时间。还可以重新取样或聚合数据来创建有规律的时间表。当一个时间表是规则的,它有排序和唯一的行时间,并且它们之间有一个统一或均匀间隔的时间步长。

  • 要找到缺少的行时间,使用伊斯米辛

  • 若要删除丢失的时间和数据,请使用RMM缺失

  • 要按行时对时间表排序,请使用索特罗斯

  • 要制作具有唯一和排序行时间的时间表,请使用独特的休息时间

  • 要制定有规律的时间表,请指定均匀间隔的时间向量并使用休息时间

按时间顺序排序

确定时间表是否排序。如果一个时间表的行时间按升序列出,那么它就是排序的。

issorted (bikeData)
ans=逻辑0

的时间表。的索特罗斯函数根据行时间(从最早到最近)对行进行排序。如果有重复行时间的行,那么索特罗斯将所有副本复制到输出。

bikeData = sortrows (bikeData);issorted (bikeData)
ans=逻辑1

识别和删除丢失的时间和数据

时间表的变量或行时间中可能有缺失的数据指示器。例如,可以将缺少的数值表示为s、 以及缺少的日期时间值纳特属性可以指定、查找、删除和填充缺失的值standardizeMissing伊斯米辛RMM缺失,fillmissing函数,分别。

查找并计算时间表变量中的缺失值。在本例中,缺失值表示未收集数据的情况。

missData = ismissing (bikeData);总和(missData)
ans=1×41 3 3 3

的输出伊斯米辛是一个逻辑矩阵,与表大小相同,将缺少的数据值标识为true。显示缺少数据指示符的所有行。

idx = (missData, 2);bikeData (idx:)
ans =3×4时刻表时间日总西行东行南南2015-08-03周一00:00南南2015-08-03:00周一南南未定义

ismissing (bikeData)只查找时间表变量中丢失的数据,而不查找时间。要找到缺少的行次数,调用伊斯米辛在行时间。

missTimes = ismissing (bikeData.Time);bikeData (missTimes:)
ans =2×4时间表时间一天总西行的往东的  ____ ___________ _____ _________ _________ NaT <定义>南南南NaT周五6 3 3

在此示例中,缺少的时间或数据值表示测量错误,可以将其排除在外。请使用删除表中包含缺少的数据值和缺少的行时间的行RMM缺失

bikeData = rmmissing (bikeData);sum (ismissing (bikeData))
ans=1×40 0 0 0
sum (ismissing (bikeData.Time))
ans = 0

删除重复次数和数据

确定是否有重复的次数和/或重复的数据行。您可能想要排除精确的重复,因为这些也可以被认为是测量错误。通过查找排序时间之间的差恰好为零的位置来识别重复时间。

idx = diff(bikeData.Time) == 0;dup = bikeData.Time (idx)
重复=3 x1 datetime数组2015-08-21 00:00:00 2015-11-19 23:00:00 2015-11-19 23:00:00

重复三次,2015年11月19日重复两次。检查与重复次数相关的数据。

比克达塔(dup(1),:)
ans =2×4时间表时间日总计西行东行2015-08-21:00星期五14 9 5-08-21:00星期五11 7 4
bikeData (dup (2):)
ans =3×4时刻表时间一天总西行的往东的  ___________________ ________ _____ _________ _________ 2015-11-19 23:00:00周四17 15 2 2015-11-19 23:00:00周四17 15 2 2015-11-19 23:00:00周四17 15 2

第一种方法有重复的次数,但数据是不重复的,而其他方法是完全重复的。当时间表行包含相同的行时间和行之间相同的数据值时,它们被认为是重复的。您可以使用独特的删除时间表中重复的行。的独特的函数还按行时间对行进行排序。

bikeData =独特(bikeData);

具有重复时间但数据不重复的行需要一些解释。请检查这些时间周围的数据。

d=dup(1)+小时(-2:2);bikeData(d,:)
ans =5×4时间表时间日总西行东行___________________ _____________ __________________ 2015-08-20 22:00:00星期四40 30 10 2015-08-20 23:00:00星期四25 18 7 2015-08-21 00:00:00星期五11 7 4 2015-08-21 00:00:00星期五14 9 5 2015-08-21 02:00:00星期五6 5

在这种情况下,复制时间可能是错误的,因为数据和周围时间是一致的。虽然它似乎代表01:00:00,但不确定这应该是什么时间。可以累积数据以说明两个时间点的数据。

sum (bikeData {dup (1), 2:})
ans=1×325 16 9

这只是一种可以手动完成的情况休息时间函数可以执行此计算。属性的惟一时间累计数据总和聚合函数。该和适用于数值数据,但不适用于时间表中的分类数据。使用变形金刚识别数值变量。

vt=vartype(“数字”);t =独特(bikeData.Time);numData =调整时间(bikeData (:, vt), t,“和”);头(numData)
ans =8×3的时间表时间Total西行东行___________________ ______________ _________ 2015-06-24 01:00:00 3 30 2015-06-24 02:00:00 1 1 0 2015-06-24 03:00:00 1 1 0 2015-06-24 05:00:00 7 3 4 2015-06-24 06:00:00 36 6 30 2015-06-24 07:00:00 141 13 128

您不能对分类数据求和,但由于一个标签表示一整天,因此每天取第一个值。您可以执行休息时间用相同的时间向量再次操作,并将时间表连接在一起。

vc=vartype(“分类”);catData =调整时间(bikeData (:, vc), t,“firstvalue”);bikeData = [catData, numData];bikeData (d,:)
ans =4×4的时间表时间日总西行东行___________________ _____________ __________________ 2015-08-20 22:00:00星期四40 30 10 2015-08-20 23:00:00星期四25 18 7 2015-08-21 00:00:00星期五25 16 9 2015-08-21 02:00:00星期五6 5

检查时间间隔一致性

这些数据似乎具有统一的一小时时间步长。要确定这是否适用于时间表中的所有行时间,请使用isregular功能。isregular返回真正的对于已排序的等间距时间(单调递增),没有重复或遗漏的时间(纳特).

isregular (bikeData)
ans=逻辑0

的输出0,或假的表示时间表中的时间间隔不均匀。更详细地探索时间间隔。

dt = diff (bikeData.Time);[min (dt);马克斯(dt)]
ans=2x1持续时间数组00:30:00 03:00:00

把时间表放在一个固定的时间间隔,使用休息时间同步并指定感兴趣的时间间隔。

确定每天的自行车数量

计算每天的计数休息时间函数。使用总和方法。这适用于数字数据,但不适用于时间表中的分类数据。使用变形金刚按数据类型识别变量。

dayCountNum=重定时(比基达(:,vt),“每天”“和”);头(dayCountNum)
ans =8×3的时间表中国UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU中国中国中国中国时间总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量WeWeWeWeWeWeWeWeWeWeWeWeWeWeWeWe总总总总总总总总总总总总总时间时间时间时间时间时间时间时间时间时间时间总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量总量-30 00:00:00 2170 1145 1025 2015-07-01 00:00:00 997 544 453

如上所述,您可以执行休息时间操作以使用适当的方法表示分类数据并将时间表连接在一起。

dayCountCat =调整时间(bikeData (:, vc),“每天”“firstvalue”);dayCount=[dayCountCat,dayCountNum];头(dayCount)
ans =8×4时间表时间日总西行东行___________________ ______________ __________________ 2015-06-24 00:00:00星期三2141 1141 1000 2015-06-25 00:00:00星期四2106 1123 983 2015-06-26 00:00:00星期五1748 970 778 2015-06-27 00:00:00星期六695 346 349 2015-06-28 00:00:00星期日153 83 70 2015-06-29 00:00:00星期一1841 978 863 2015-06-3000:00星期二2170 1145 1025 2015-07-01 00:00:00星期三997 544 453

同步自行车计数和天气数据

通过比较自行车数量和天气数据来检验天气对骑车行为的影响。载入天气时间表,其中包括来自波士顿的历史天气数据,包括风暴事件。

负载BostonWeatherData头(weatherData)
ans =8×3的时间表时间温度湿度事件___________ ____________ ________ ____________ 01- 7- 2015 72 78雷暴02- 7- 2015 72 60无03- 7- 2015 70 56无04- 7- 2015 67 75无05- 7- 2015 72 67无06- 7- 2015 74 69无07- 7- 2015 75 77雨08- 7- 2015 79 68雨

要总结时间表中的时间和变量,使用总结功能。

总结(weatherData)
x1 datetime值:RowTimes:时间:383分钟01 - 2015中位数08年7月- 2016年1月2016 Max 17 - 7月步伐24:00:00变量:TemperatureF: x1双重价值:383分钟2 55 Max 85湿度中位数:383 x1双重价值:分钟29 64 Max 97事件中位数:383 x1分类值:7冰雹雨108雨雪雾4雪18雷暴12没有233

将自行车数据与天气数据结合成一个通用的时间矢量使用同步。您可以使用参考页上记录的任何方法对时间表数据进行重新采样或汇总同步功能。

将两个时间表的数据同步到一个共同的时间向量,这个时间向量是由它们各自的每日时间向量的交集构成的。

data =同步(dayCount weatherData,“交叉口”);头(数据)
ans =8×7时间表时间日总西行东行温度湿度事件___________________ ______________ __________________ ____________ ________ ____________ 2015-07-01 00:00:00星期三997 544 453 72 78雷雨2015-07-02 00:00:00星期四1943 1033 910 72 60无2015-07-03 00:00:00星期五870 454 416 70 56无2015-07-04 00:00:00星期六669 328 341 67 75无2015-07-05 00:00:00 Sunday 702 407 295 72 67无2015-07-06 00:00:00 Monday 1900 1029 871 74 69无2015-07-07 00:00:00 Tuesday 2106 1140 966 75 77 Rain 2015-07-08 00:00:00 Wednesday 1855 984 871 79 68 Rain

在不同的y轴上比较自行车流量和室外温度的变化趋势。从数据中删除周末以实现可视化。

idx=~isweekend(data.Time);weekdayData=data(idx{“TemperatureF”“总计”});图YY轴绘图(weekdayData.Time,weekdayData.Total)ylabel(“自行车计数”)yyaxis正确的情节(weekdayData.Time weekdayData.TemperatureF) ylabel ('温度(\circ F)')头衔(“自行车数量和温度随时间变化”) xlim((最小(data.Time)最大(data.Time)))

这张图显示,交通和天气数据可能也会遵循类似的趋势。放大情节。

xlim([datetime(“2015-11-01”)、日期时间(“2016-05-01”)])

趋势是相似的,这表明在寒冷的日子里骑车的人越来越少。

按星期和时间分析

根据不同的时间间隔检查数据,如星期几和一天中的时间。使用varfun对变量进行分组计算。指定总和函数具有函数句柄和使用名称-值对的分组变量和首选输出类型。

byDay = varfun (@sum bikeData,“分组变量”“天”...“OutputFormat”“桌子”
byDay =7×5表日GroupCount sum_Total sum_西向sum_东向_________ __________ _________ _____________ _____________星期日1344 25315 12471 12844星期一1343 79991 39219 40772星期二1320 81480 39695 41785星期三1344 86853 41726 45127星期四1344 87516 42682 44834星期五1342 76643 36926 39717星期六1343 30292 14343 15949
图酒吧(byDay {: {“sum_Westbound”"sum_东行"}})传说({“西行”“东行”},“位置”“eastoutside”)克斯蒂克拉贝尔斯酒店({“太阳”“妈妈”“星期二”“结婚”“星期四”“星期五”“Sat”})头衔(“每周的自行车数”

条形图显示平日交通较为繁忙。此外,东西方向也存在差异。这可能表明人们在进出城市时倾向于走不同的路线。另一种可能性是,一些人在一天进入,另一天返回。

确定一天的时间和使用varfun用于分组计算。

bikeData。HrOfDay =小时(bikeData.Time);byHr = varfun (@mean bikeData (: {“西行”“东行”“HrOfDay”}),...“分组变量”“HrOfDay”“OutputFormat”“桌子”);头(byHr)
ans =8×4表HrOfDay GroupCount mean_Westbound mean_Eastbound _______ __________ ______________ ______________ 0 389 5.4396 1.7686 1 389 2.7712 0.87147 2 391 1.8696 0.58312 3 391 0.7468 0.289 4 391 0.52685 1.0026 5 391 0.70588 4.7494 6 391 3.1228 22.097 7 391 9.1176 63.54
巴(拜尔{:{“mean_Westbound”“mean_Eastbound”}})传奇(“西行”“东行”“位置”“eastoutside”)包含(一天的小时) ylabel (“自行车计数”)头衔(“按小时计算的平均自行车计数”

在典型的通勤时间,大约上午9:00和下午5:00,交通会出现高峰。此外,东行方向和西行方向之间的趋势不同。通常,西行方向是剑桥地区周围的住宅区和大学。东行方向是波士顿。

当天晚些时候,西行方向的交通较东行方向繁忙。这可能表明大学的时间表和由于该地区的餐馆而造成的交通。检查趋势,以天的星期和小时的一天。

byHrDay=varfun(@sum,bikeData,“分组变量”, {“HrOfDay”“天”},...“OutputFormat”“桌子”);头(byHrDay)
ans =8×6表HrOfDay天GroupCount sum_Total sum_Westbound sum_Eastbound  _______ _________ __________ _________ _____________ _____________ 周日56 473 345 128 0 0周一55 202 145 57 0周二55 297 213 84 0周三56周四56 436 324 112 374 286 88 0 0周五55 442 348 94 0周六周日56 56 580 455 125 333 259 74

要安排时间表,使星期几是可变的,请使用解开功能。

hrAndDayWeek=取消堆栈(按hrday(:{“HrOfDay”“天”“sum_Total”}),“sum_Total”“天”);头(hrAndDayWeek)
ans =8×8表HrOfDay周日周一周二周三周四周五周六  _______ ______ ______ _______ _________ ________ ______ ________ 0 473 202 297 374 436 442 580 333 81 147 168 173 183 332 86 198 77 68 93 128 141 254 3 51 41 43 44 50 61 80 81 117 101 108 80 60 419 105 353 407 381 340 128 275 1750 1867 2066 1927 1625 351 553 5355 5515 5818 75731 4733 704
hrAndDayWeek. hrofday,hrAndDayWeek{:,2:end}) ylim([0 24]) xlim([0 8]) xticks(1:7) xticklabels({“太阳”“妈妈”“星期二”“结婚”“星期四”“星期五”“Sat”})伊拉贝尔(“小时”)头衔(“以小时和天计算自行车数量”

周一至周五的正常工作日也有类似的趋势,高峰时间是高峰时间,晚上的交通量逐渐减少。周五的交通量较少,但总体趋势与其他工作日相似。周六和周日的趋势相似,没有高峰时间,一天中的晚些时候交通量更多。周一至周五的晚间趋势也类似,周五成交量减少。

高峰时段交通分析

要检查一天中的总时间趋势,请按高峰时间分割数据。可以使用离散化函数。例如,将数据分成组,以便AMRush一天PMRush.然后使用varfun按组计算平均值。

bikeData。(bikeData HrLabel =离散化。HrOfDay,[0、6、10、15、19日24),“分类”...“AM”“RushAM”“天”“RushPM”“点”});byHrBin = varfun (@mean bikeData (: {“总计”“HrLabel”}),“分组变量”“HrLabel”...“OutputFormat”“桌子”
比尔宾=5×3表HrLabel GROUPTCOUNT平均值总计拉什姆1564.893天1955 45.612拉什姆1564.066下午1955 35.198
bar(byHrBin.mean_Total) cats = categories(byHrBin.HrLabel);xticklabels(猫)标题(“高峰时段的自行车数量”

总的来说,在晚上和早上高峰时间,该地区的交通量大约是一天中其他时间的两倍。清晨,该地区的交通量很少,但晚上和深夜的交通量仍然很大,与早上和晚上高峰时间以外的一天相比较。

这个话题有用吗?