从 csv 文件中统计前几名相关信息【JAVA计算系列】

例题描述和简单分析

有csv文件,第一列是id,第二列是roomname,第三列是date,第四列是time,第五列是LOB(length of booking),第六列是PB(person booking),如下:

id,roomname,date,time,LOB,PB

1,Gower,2000-01-01,0:00:00,281,Jack

2,Usk,2000-01-01,0:00:00,291,Jack

3,Wye,2000-01-01,0:00:00,283,Jack

4,Bala,2000-01-01,0:00:00,282,Jack

5,Pen y Fan,2000-01-01,0:00:00,292,Jack

6,Llangorse,2000-01-01,0:00:00,290,Jack

7,Snowdon,2000-01-01,0:00:00,288,Jack

8,Taff,2000-01-01,0:00:00,296,Jack

9,Cadair Idris,2000-01-01,0:00:00,292,Jack

现在需要统计订房时间最长的n个房间的名字和订房时间。例如,n为5,结果如下:

1: Taff 296

2: Cadair Idris 292

3: Pen y Fan 292

4: Usk 291

5: Llangorse 290

解法及简要说明

在集算器中编写脚本p1.dfx,如下所示:


A

1

=file("csv.csv").import@tc(roomname,LOB)

2

=A1.top(n;-LOB)

3

=if(n==1,output("RoomName   : "/A2.roomname/" "/A2.LOB),output(A2.(#/":   "/roomname/" "/LOB).concat@n()))

简要说明:

设置网格参数n

A1   读取csv文件中的roomname列和LOB列

A2  获取前n个LOB(length of booking)最大的记录,其中n为脚本的参数

A3  若n等于1,输出订房时间最长的房间名和订房时间,否则输出订房时间最长的n个房间名和订房时间。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值