mongo中的时间戳如何转换成正常的日期格式
场景: 由于业务开发过程中后端为做日期格式的转换导致mongo中根据系统时间产生 类似语NumberLong(1476407933621)的时间戳, 而我们此时又需要将其转换成自己熟知的日期格式方便查看日期.
借此记录下便于后期碰到类似问题进行处理. 代码只是为了使用,不严谨的地方希望一起探讨并改正.
Json插件采用Gson,做之前先引包
转换后日期
=====================BEGIN=====================
第1次访问 时间为:2016-10-14 09:18:22
第2次访问 时间为:2016-10-14 09:18:53
第3次访问 时间为:2016-10-22 14:18:49
第4次访问 时间为:2016-10-22 14:20:18
第5次访问 时间为:2016-10-22 14:32:45
第6次访问 时间为:2016-10-22 14:33:31
第7次访问 时间为:2016-10-22 14:40:32
第8次访问 时间为:2016-10-23 00:05:18
第9次访问 时间为:2016-10-23 16:42:06
第10次访问 时间为:2016-10-24 11:52:31
=====================END=======================
第一步:mongo中取出数据并自己创建个文本文件进行保存
mongo中数据格式(具体数据参照自己实际业务)
/* 1 */
{
}
/* 2 */
{
}
第二步:执行以下代码
package test; import java.io.BufferedReader; import java.io.File; import java.io.FileReader; import java.text.SimpleDateFormat; import java.util.Date; import com.google.gson.Gson; import com.google.gson.JsonArray; /** * 将mongo中的时间戳转换正常的日期格式 * * @author Mr.Cui * */ public class testTime { public static void main(String[] args) { System.out.println("=====================BEGIN====================="); String filePath = "C:/Users/Administrator/Desktop/stamepToDate.txt"; beginChange(filePath); System.out.println("=====================END======================="); } /** * 开始转换 */ public static void beginChange(String filePath) { File file = new File(filePath); if (file.exists() && file.length() == 0) { System.out.println("文件内容为空"); return; } StringBuilder result = new StringBuilder(); try { BufferedReader br = new BufferedReader(new FileReader(file));// 构造一个BufferedReader类来读取文件 String s = null; while ((s = br.readLine()) != null) {// 使用readLine方法,一次读一行 if (!s.contains("*")) { s = (System.lineSeparator() + s); if (s.contains("}")) { s = s + ","; } result.append(s); } } br.close(); changeAndOutDate(result); } catch (Exception e) { e.printStackTrace(); System.out.println("系统发生异常数据未被成功转换"); return; } } /** * 改变字符串时间戳为 类似于2016-10-24 11:52:31 的日期格式 * * @param result * 读取到的字符串 */ public static void changeAndOutDate(StringBuilder result) { Gson gson = new Gson(); String jsonArrayStr = "[" + result.substring(0, result.length() - 1) + "]"; JsonArray jsonArray = gson.fromJson(jsonArrayStr.toString(), JsonArray.class); for (int i = 0; i < jsonArray.size(); i++) { String str = jsonArray.get(i).getAsJsonObject().get("create_time").getAsString(); str = str.substring(str.indexOf("(") + 1, str.lastIndexOf(")")); SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); long lt = new Long(str); Date date = new Date(lt); str = simpleDateFormat.format(date); System.out.println("第" + (i + 1) + "次访问 时间为:" + str); } } }