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);
		}

	}
}

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值