场景: 由于业务开发过程中后端为做日期格式的转换导致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);
}
}
}