String转成JSON
这个依赖很重要,我们将围绕fastjson中的JSONObject这个类来谈转换

  1. <dependency>
  2. <groupId>com.alibaba</groupId>
  3. <artifactId>fastjson</artifactId>
  4. <version>1.2.15</version>
  5. </dependency>

String转成JSON

  1. String json = "{"abc":"1","hahah":"2"}";
  2. JSONObject jsonObject = JSONObject.parseObject(content);

一句话就能解决,非常便捷。
想要取出值,可以对`jsonObject`进行操作:
jsonObject.getString("abc");
结果为:`1`

将String转为list后转为JSON

  1. List<String> list = new ArrayList<String>();
  2. list.add("username");
  3. list.add("age");
  4. list.add("sex");
  5. JSONArray array = new JSONArray();
  6. array.add(list);

将String转为map后转为JSON

  1. Map<String, String> map = new HashMap<String, String>();
  2. map.put("abc", "abc");
  3. map.put("def", "efg");
  4. JSONArray array_test = new JSONArray();
  5. array_test.add(map);
  6. JSONObject jsonObject = JSONObject.fromObject(map);

特别注意:从JSONObject中取值,碰到了数字为key的时候,如

  1. {
  2. "userAnswer": {
  3. "28568": {
  4. "28552": {
  5. "qId": "28552",
  6. "order": "1",
  7. "userScore": {
  8. "score": 100
  9. },
  10. "answer": {
  11. "28554": "28554"
  12. },
  13. "qScore": "100.0",
  14. "qtype": "SingleChoice",
  15. "sId": "28568"
  16. }
  17. }
  18. },
  19. "paperType": "1",
  20. "paperOid": "28567",
  21. "instanceId": 30823,
  22. "remainingTime": -1,
  23. "examOid": "28570"
  24. }

获取“userAnswer”的value,再转成JSON,可仿照如下形式:
JSONObject userJson = JSONObject.parseObject(jsonObject.getString("userAnswer"));
但是想获取key"28568"就没这么容易了。直接像上述的写法,会报错。
我们浏览fastjson中的源码,总结下,应该如下写:
JSONObject question = (JSONObject) JSONObject.parseObject(section.getString("28568"), Object.class);
整体代码:

dao代码很容易,就不贴出来了。

  1. package com.xiamenair.training.business.service;
  2. import com.alibaba.fastjson.JSONObject;
  3. import com.xiamenair.training.business.dao.elearningdao.ELearningExamInstanceDao;
  4. import com.xiamenair.training.business.dao.masterdao.ELearningChoiceRecordDao;
  5. import com.xiamenair.training.business.model.LasChoiceRecord;
  6. import com.xiamenair.training.business.model.entity.elearning.LasExamInstance;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.scheduling.annotation.Scheduled;
  9. import org.springframework.stereotype.Service;
  10. import java.math.BigDecimal;
  11. import java.sql.Blob;
  12. import java.sql.SQLException;
  13. import java.text.SimpleDateFormat;
  14. import java.util.*;
  15. @Service
  16. public class ChoiceRecordService {
  17. //查询数据Dao
  18. @Autowired
  19. private ELearningChoiceRecordDao eLearningChoiceRecordDao;
  20. //转储数据Dao
  21. @Autowired
  22. private ELearningExamInstanceDao eLearningExamInstanceDao;
  23. private ChoiceRecordService() {
  24. }
  25. private static class SingletonRecordInstance {
  26. private static final LasChoiceRecord choiceRecord = new LasChoiceRecord();
  27. }
  28. public static LasChoiceRecord getMapInstance() {
  29. return SingletonRecordInstance.choiceRecord;
  30. }
  31. private static SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
  32. /**
  33. * 定时任务,每天定时将E学网考试数据分析并转储
  34. *
  35. * @param : instanceIdList
  36. * @return : void
  37. * @author : 28370·皮育才
  38. * @date : 2018/11/20
  39. **/
  40. @Scheduled(cron = "00 00 01 * * ?")
  41. public void analysisChoiceRecord() {
  42. //获取前一天的时间
  43. Date date = new Date();
  44. Calendar calendar = Calendar.getInstance();
  45. calendar.setTime(date);
  46. calendar.add(calendar.DATE, -1);
  47. date = calendar.getTime();
  48. String dateString = simpleDateFormat.format(date);
  49. List<BigDecimal> instanceIdList = eLearningExamInstanceDao.findInstanceIdByFinishTime(dateString);
  50. if(0 != instanceIdList.size()){
  51. LasChoiceRecord lasChoiceRecord = getMapInstance();
  52. instanceIdList.stream().forEach(instanceId -> {
  53. Blob answerBlob = eLearningExamInstanceDao.findUserAnswer(instanceId);
  54. Long userId = eLearningExamInstanceDao.findUserId(instanceId);
  55. String content = null;
  56. try {
  57. content = new String(answerBlob.getBytes((long) 1, (int) answerBlob.length()));
  58. } catch (SQLException e) {
  59. e.printStackTrace();
  60. System.out.println("SQLEXCEPTION:" + e);
  61. }
  62. JSONObject jsonObject = JSONObject.parseObject(content);
  63. //针对本section的"公共"属性直接设置
  64. lasChoiceRecord.setUserId(userId);
  65. lasChoiceRecord.setPaperType(jsonObject.getString("paperType"));
  66. lasChoiceRecord.setPaperId(jsonObject.getString("paperOid"));
  67. lasChoiceRecord.setExamInstanceId(jsonObject.getString("instanceId"));
  68. lasChoiceRecord.setRemainingTime(jsonObject.getString("remainingTime"));
  69. lasChoiceRecord.setExamId(jsonObject.getString("examOid"));
  70. //针对section中的题目进行细化循环拆分
  71. JSONObject userJson = JSONObject.parseObject(jsonObject.getString("userAnswer"));
  72. Set sectionSet = userJson.keySet();
  73. Iterator<String> setIt = sectionSet.iterator();
  74. analyzeAnswer(lasChoiceRecord, userJson, setIt);
  75. });
  76. }
  77. }
  78. private void analyzeAnswer(LasChoiceRecord lasChoiceRecord, JSONObject userJson, Iterator<String> setIt) {
  79. while (setIt.hasNext()) {
  80. //对每个question进行再次拆分出题目
  81. JSONObject section = (JSONObject) JSONObject.parseObject(userJson.getString(setIt.next()), Object.class);
  82. Set questionSet = section.keySet();
  83. Iterator<String> queIt = questionSet.iterator();
  84. while (queIt.hasNext()) {
  85. JSONObject question = (JSONObject) JSONObject.parseObject(section.getString(queIt.next()), Object.class);
  86. String userAnswer = question.getString("answer");
  87. String userScore = question.getString("userScore");
  88. lasChoiceRecord.setQuestionId(question.getString("qId"));
  89. lasChoiceRecord.setRecordId(UUID.randomUUID().toString());
  90. eLearningChoiceRecordDao.save(lasChoiceRecord);
  91. }
  92. }
  93. }
  94. }

JSON转换的实现的更多相关文章

  1. json转换成对象

    在json转换成对象时,json的key会与java 类的字段一一对应.如果没有映射上的java字段会在该数据类型上填充默认值,如int 0,String null 等. 没有映射的json key在 ...

  2. Json转换利器Gson之实例一-简单对象转化和带泛型的List转化 (转)

    Gson 是 Google 提供的用来在 Java 对象和 JSON 数据之间进行映射的 Java 类库.可以将一个 JSON 字符串转成一个 Java 对象,或者反过来. jar和源码下载地址: h ...

  3. json转换数据后面参数要带ture,代码

    强大的PHP已经提供了内置函数:json_encode() 和 json_decode().很容易理解,json_encode()就是将PHP数组转换成Json.相反,json_decode()就是将 ...

  4. iOS Json转换模型库:YYModel

    iOS Json转换模型库:YYModel   其实在研究这个库之前,市面上已经有很多类似的模型序列化成JSON及反序列化库(如Mantle.MJExtension)了,推荐他只是因为他高端的性能和容 ...

  5. miniui datagrid 保存到服务端,使用.NET 自带 JSON 转换时发现日期格式不兼容。

    使用 miniui datagrid 修改表格后,保存到服务端,然后使用 .NET 自带 JSON 转换,会抛出DateTime 内容“2015-12-27T11:02:28”未按 JSON 的要求以 ...

  6. 从零开始学android开发-Json转换利器Gson之实例

    Gson 是 Google 提供的用来在 Java 对象和 JSON 数据之间进行映射的 Java 类库.可以将一个 JSON 字符串转成一个 Java 对象,或者反过来. jar和源码下载地址: h ...

  7. Jackson框架,json转换

    Jackson可以轻松的将Java对象转换成json对象和xml文档,同样也可以将json.xml转换成Java对象. 前面有介绍过json-lib这个框架,在线博文:http://www.cnblo ...

  8. json转换(c#后台生成json的方法)

    此文转自:http://bbs.csdn.net/topics/380200497,为了方便自己记忆才以文章形式保存. using System; using System.Collections.G ...

  9. C#将XML转换成JSON转换XML

    原文:C#将XML转换成JSON转换XML using System; using System.Collections.Generic; using System.Linq; using Syste ...

  10. ELK系列~Nxlog日志收集加转发(解决log4日志换行导致json转换失败问题)

    本文章将会继承上一篇文章,主要讲通过工具来进行日志的收集与发送,<ELK系列~NLog.Targets.Fluentd到达如何通过tcp发到fluentd> Nxlog是一个日志收集工具, ...

随机推荐

  1. Github Pull Request的提出与采纳

    这一文来简要介绍一下Github Pull Request(以下简称PR)的使用方法: 作为PR的提出者,如何对某个仓库提交PR,如何根据仓库管理者对所提交PR的反馈对PR进行完善 作为PR的接收者, ...

  2. ClickOnce部署,修改deploymentProvider

    打开 以.application 为后缀的文件,找到并修改 <deploymentProvider codebase="" /> 即可

  3. ajax循环展示某段代码

    ajax内定义function,根据条件递归调用即可. success: function(data){ if (dataList[i].subModuleList){ sublist(dataLis ...

  4. Euler Sums系列(一)

    \[\Large\sum_{n=1}^{\infty} \frac{H_{n}}{2^nn^4}\] \(\Large\mathbf{Solution:}\) Let \[\mathcal{S}=\s ...

  5. Laravel Vuejs 实战:开发知乎 (8)美化编辑器

    1.使用UEditor增量包: simple-ueditors 执行下载: git clone https://github.com/JellyBool/simple-ueditor.git 2.用此 ...

  6. HBase的完全分布式搭建

    一.HBase的安装模式 ①单机安装:不依赖于Hadoop的HDFS,配置完即可使用,好处是便于测试,坏处是不具备分布式数据存储的能力. ②伪分布式安装:单台主机模拟真实环境. ③完全分布式安装:多台 ...

  7. C语言:将字符串中的字符逆序输出,但不改变字符串中的内容。-在main函数中将多次调用fun函数,每调用一次,输出链表尾部结点中的数据,并释放该结点,使链表缩短。

    //将字符串中的字符逆序输出,但不改变字符串中的内容. #include <stdio.h> /************found************/ void fun (char ...

  8. 9. 图解分析Redis的RDB和AOF两种持久化机制的原理

    1.RDB和AOF两种持久化机制的介绍 2.RDB持久化机制的优点3.RDB持久化机制的缺点4.AOF持久化机制的优点5.AOF持久化机制的缺点6.RDB和AOF到底该如何选择 我们已经知道对于一个企 ...

  9. Stream:java1.8新特性

    原 Stream:java1.8新特性 2017年08月01日 18:15:43 kekeair-zhang 阅读数:392 标签: streamjava1-8新特性 更多 个人分类: 日记 版权声明 ...

  10. JQuery选择器&过滤器

    JQuery对象: JQuery对象的本质上是DOM数组,它对DOM元素进行了封装 JQuery对象和JavaScript对象可以互转(\$()/$obj()[i]),但是JQuery对象和Javas ...