java连接MongoDB查询导出为excel表格

背景

由于项目需求,每个星期需要统计每个公众号7天的访问数,月底就需要统计一个月的访问数,40多个公众号,每次手动统计都需要花费1个小时,总之是一项无技术耗时耗神的手工活。于是,想写个程序来统计,每次只需要运行下代码,输入一些配置信息就导出为excel表格,直接复制完事,但是水平有限,就只用java写了个。


demo下载

下载地址:http://download.csdn.net/detail/musuny/8769499


程序说明

  • 依赖外部jar包
    • fastjson-1.1.36.jar:阿里巴巴自主研发的json工具,性能好,本文主要用于数据的存取
    • mongo-java-driver-2.13.2.jar:java 连接mongo驱动包,此包为关键包不可或缺
    • poi-3.12.jar:用于创建Excel表格的jar包
  • PublicVisit类:主要实现统计功能的类
    • init(ip,port,db,collection):初始化连接mongo的ip地址、端口号、数据库、查询集合
    • destroy():在程序执行完成执行该函数,关闭数据库的连接、垃圾回收等
    • readIdsFromFile(filePath):从指定路径下的文件读取公众号id
      公众号id内容示例:
      公众号id示例
    • getAll(filePath,startTime,endTime):参数分别代表公众号id所在的文件路径、统计数据的开始时间和截止时间,时间格式为字符串的yyyyMMdd
    • exportAsExcel(array,exportPath):参数分别代表JSONArray类型的统计结果、导出excel的表格路径
    • main():程序入口
  • VisitDetail类:访问数据类,包括公众号id属性以及JSONArray访问统计集合属性

步骤

第一步:运行程序

demo我已经build成一个jar包,运行方式也特别简单,在jar所在路径按住shift+鼠标右键然后点击“在此处打开命令行窗口”,输入命令:java -jar MongoDB-Demo.jar ,即可运行程序。

第二步:根据提示输入配置参数

按照程序运行提示信息输入相关配置信息,具体的需要输入自己的参数,运行截图:
程序运行截图

第三步:打开保存的excel表格

打开保存在E:/visit.xls表格,查看统计到的数据,比较理想,达到了想要的统计结果,结束了痛苦的手工统计,看看这个表格吧,可以想象手工统计1000+个数据是多么的无聊。截图:
统计结果表格信息


总结

终于结束了痛苦的人工统计,O(∩_∩)O哈哈~,如果需要程序源码,请联系我!


关于我

  • Q Q:1250052380
  • 邮箱:1250052380@qq.com
Navicat15 for MongoDB 是一款功能强大的数据库管理工具,专门为MongoDB数据库而设计。它提供了一系列易于使用且丰富的功能,使得管理和开发MongoDB数据库变得更加容易和高效。 首先,Navicat15 for MongoDB具备直观的用户界面,让用户可以轻松地连接和管理多个MongoDB数据库。用户可以使用它来执行各种操作,如创建、修改和删除数据库、集合和文档,以及执行复杂的查询和聚合操作。 其次,Navicat15 for MongoDB提供了强大的数据编辑和可视化工具。用户可以方便地编辑文档的内容,并利用内置的数据验证功能确保数据的完整性。此外,它还提供了一系列的数据可视化图,帮助用户更好地理解和分析数据。 此外,Navicat15 for MongoDB支持多种数据导入和导出格式,如CSV、Excel、JSON和SQL等。这使得用户可以轻松地将数据从其他数据库或文件导入到MongoDB中,也可以将MongoDB数据导出到其他格式进行进一步的处理和分析。 还值得一提的是,Navicat15 for MongoDB提供了丰富的安全功能,如SSH隧道、SSL连接数据库用户管理。这些功能确保了数据在传输和存储过程中的安全性和保密性。 总之,Navicat15 for MongoDB是一款功能强大、易于使用且具有丰富功能的数据库管理工具。它为用户提供了完整的MongoDB管理和开发解决方案,帮助他们更好地管理和利用MongoDB数据库。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

羽轩GM

您的鼓励是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值