JSON,字符串,MAP转换
package com.tree.autotest.testcase.IAuditBillDetailService; import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.datatrees.basisdata.bankbill.service.IAuditBillDetailService;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.google.common.collect.Maps;
import com.tree.autotest.BaseJunit4Test;
import com.tree.autotest.commons.CommonUtil_2;
import com.tree.autotest.commons.TestCase;
import com.tree.autotest.jdbc.DBIdConstant;
import com.tree.autotest.jdbc.ManagedSqlUtil;
import org.junit.After;
import org.junit.Assert;
import org.junit.Before;
import org.junit.Test;
import org.springframework.beans.factory.annotation.Autowired; import javax.annotation.PostConstruct;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.Map; /**
* Created by lyh on 17/2/23.
*/
public class Test06 extends BaseJunit4Test{
@Autowired
private IAuditBillDetailService iAuditBillDetailService; private boolean handleOk;
private String insertSql1,insertSql2,insertSql3,insertSql4;
private static String excel;
private static Map allCases;
private Integer testuser;
private Integer billid;
private String spare; private Map<Short, String> bankMap = Maps.newHashMap(); @PostConstruct
public void init() {
bankMap.put((short)1, "招商银行");
bankMap.put((short)2, "广发银行");
bankMap.put((short)3, "光大银行");
bankMap.put((short)4, "华夏银行");
bankMap.put((short)5, "建设银行");
bankMap.put((short)6, "民生银行");
bankMap.put((short)7, "农业银行");
bankMap.put((short)8, "浦发银行");
bankMap.put((short)9, "兴业银行");
bankMap.put((short)10, "中国银行");
bankMap.put((short)11, "中信银行");
bankMap.put((short)12, "工商银行");
bankMap.put((short)13, "交通银行");
bankMap.put((short)14, "平安银行");
bankMap.put((short)15, "邮政储蓄银行");
bankMap.put((short)16, "广州农商银行");
bankMap.put((short)17, "浙江农信");
bankMap.put((short)18, "上海银行");
bankMap.put((short)19, "广州银行");
bankMap.put((short)20, "北京银行");
bankMap.put((short)21, "南京银行");
bankMap.put((short)22, "徽商银行");
bankMap.put((short)23, "天津银行");
bankMap.put((short)24, "苏州银行");
bankMap.put((short)25, "江苏银行");
bankMap.put((short)26, "宁波银行");
bankMap.put((short)27, "杭州银行");
bankMap.put((short)28, "重庆银行");
bankMap.put((short)29, "长沙银行");
bankMap.put((short)30, "民泰银行");
bankMap.put((short)31, "台州银行");
bankMap.put((short)32, "浙商银行");
} @Before
public void setUp() throws SQLException {
excel = "src/main/resources/case/IAuditBillDetailService/TestT06.xlsx";
allCases = CommonUtil_2.getAllCases(excel);
} @Test
public void test_case_1() throws Exception { //获取用户ID
TestCase testcase = CommonUtil_2.getTestCaseBean(allCases, "case1", "case1-1");
testuser = Integer.valueOf(testcase.param1);
billid = Integer.valueOf(testcase.param2);
spare = testcase.param3; //获取SQL
insertSql1 = testcase.stepSql;
insertSql2 = CommonUtil_2.getTestCaseBean(allCases, "case1", "case1-2").stepSql;
insertSql3 = CommonUtil_2.getTestCaseBean(allCases, "case1", "case1-3").stepSql;
insertSql4 = CommonUtil_2.getTestCaseBean(allCases, "case1", "case1-4").stepSql; //删除,添加数据
handleOk &= deleteData(testuser,spare);
handleOk &= ManagedSqlUtil.insertBySql(insertSql1, DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.insertBySql(insertSql2,DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.insertBySql(insertSql3,DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.insertBySql(insertSql4,DBIdConstant.MySql_Basisdata_ID);
//更新数据
handleOk &=updateBillId(testuser,spare);
// Date date =DateTime.now().toDate();
// DateTime deadline = new DateTime(date).plusMonths(-18);
// DateTime specialDeadline = deadline.dayOfMonth().withMinimumValue(); // System.out.println("DateUtils.getDateTimeNow().toDate()" + specialDeadline); //预期值列表
List<BankBillDetail_test> excepted_detaillist = get_excepted_details(testuser); //++++++++++++++实际值+++++++++++++
String actual_value =
iAuditBillDetailService.T06(testuser);
System.out.println("actual_value值:" + actual_value);
//字符串解析
String summary = JSON.parseObject(actual_value).getString("Summary");
String Detail = JSON.parseObject(actual_value).getString("Detail");
JSONArray list =JSON.parseArray(Detail);
//断言
Assert.assertEquals("List", summary);
Assert.assertNotNull(list);
for(int i =0;i<list.size();i++) { String st = list.get(i).toString();//list单个元素转换为字符串
ObjectMapper objectMapper = new ObjectMapper();
Map map = objectMapper.readValue(st, Map.class);//将字符串转换为Map.
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
Date date=sdf.parse(map.get("PostDate").toString());//将字符串转换为Date类型
Assert.assertEquals(bankMap.get(excepted_detaillist.get(i).getBankId()), map.get("BankName"));
Assert.assertEquals(excepted_detaillist.get(i).getCardNo(), map.get("CardNo"));
Assert.assertEquals(excepted_detaillist.get(i).getTransTypeLevel1(), map.get("Type"));
Assert.assertEquals(excepted_detaillist.get(i).getDescription(), map.get("Description"));
Assert.assertEquals(excepted_detaillist.get(i).getPostDate().getTime(),date.getTime());
} } @After
public void tearDown() throws SQLException {
handleOk &= deleteData(testuser,spare);
} //定义数据清理
public boolean deleteData(Integer userid,String spare) {
String deleteSql1 = "delete from t_bill where userid="+userid+" ;";
String deleteSql2 = "delete from t_bill_detail where spare1='"+spare+"';";
String deleteSql3 = "delete from t_bill_extrainfo where userid = "+userid+";";
String deleteSql4 = "delete from t_bill_installment_summary where spare1='"+spare+"' ;";
handleOk &= ManagedSqlUtil.deleteBySql(deleteSql1, DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.deleteBySql(deleteSql2, DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.deleteBySql(deleteSql3, DBIdConstant.MySql_Basisdata_ID);
handleOk &= ManagedSqlUtil.deleteBySql(deleteSql4, DBIdConstant.MySql_Basisdata_ID);
return handleOk;
} public Boolean updateBillId(Integer userId,String Spare) throws SQLException{
String searchSql="select Id from t_bill where userid="+userId+";";
ResultSet rs =ManagedSqlUtil.selectBySql(searchSql,DBIdConstant.MySql_Basisdata_ID);
List<Integer> list = new ArrayList<Integer>();
while(rs.next()){
list.add(rs.getInt(1));
}
//更新t_bill_detail
String updateSql1="update t_bill_detail set billid="+list.get(0)+" where spare1='"+Spare+"';";
handleOk &= ManagedSqlUtil.updateBySql(updateSql1,DBIdConstant.MySql_Basisdata_ID);
//更新t_bill_extrainfo
String updateSql2="update t_bill_extrainfo set billid="+list.get(0)+" where userid="+userId+";";
handleOk &= ManagedSqlUtil.updateBySql(updateSql2, DBIdConstant.MySql_Basisdata_ID);
//更新t_bill_installment_summary
String updateSql3="update t_bill_installment_summary set billid="+list.get(0)+" where spare1='"+Spare+"';";
handleOk &= ManagedSqlUtil.updateBySql(updateSql3, DBIdConstant.MySql_Basisdata_ID);
return handleOk;
}
public List<BankBillDetail_test> get_excepted_details(Integer userid) throws SQLException {
String searchSql = "select BankId,CardNo,Level1TransType,Description,AmountMoney,PostDate from t_bill_detail where level1TransType='Level1_Comsumption' and TransactionTypeId =8 and billid in (select id from t_bill where userid="+userid+");";
ResultSet rs =ManagedSqlUtil.selectBySql(searchSql,DBIdConstant.MySql_Basisdata_ID);
List<BankBillDetail_test> list = new ArrayList<BankBillDetail_test>();
while(rs.next()){
BankBillDetail_test bankBillDetail = new BankBillDetail_test();
bankBillDetail.setBankId(rs.getShort("BankId"));
bankBillDetail.setCardNo(rs.getString("CardNo"));
bankBillDetail.setTransTypeLevel1(rs.getString("Level1TransType"));
bankBillDetail.setDescription(rs.getString("Description"));
bankBillDetail.setAmountManey(rs.getDouble("AmountMoney"));
bankBillDetail.setPostDate(rs.getDate("PostDate"));
list.add(bankBillDetail);
}
return list;
}
}
JSON,字符串,MAP转换的更多相关文章
- Android项目开发全程(四)-- 将网络返回的json字符串轻松转换成listview列表
前面几篇博文介绍了从项目搭建到获取网络字符串,对一个项目的前期整体工作进行了详细的介绍,本篇接着上篇介绍一下怎么样优雅将网络返回的json字符串轻松转换成listview列表. 先上图,看一下效果. ...
- JSON字符串自动转换
package com.zkn.newlearn.json; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObj ...
- Java对象与Json字符串的转换
Java对象与Json字符串的转换 JSON是一种轻量级的数据交换格式,常用于前后端的数据交流 后端 : 前端 Java对象 > JsonString Java对象 < jsonStrin ...
- JAVA中使用alibaba fastjson实现JSONObject、Object、Json字符串的转换
JAVA中使用alibaba fastjson实现JSONObject.Object.Json字符串的转换 Object转JSON字符串:String jsonStr = JSONObject.toJ ...
- C# 对象与JSON字符串互相转换的三种方式
C# 对象与JSON字符串互相转换的三种方式 JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式. 关于内存对象和JSON字符串的相互转换, ...
- JSON字符串互相转换的三种方式和性能比较
C# 对象与JSON字符串互相转换的三种方式 JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式. 关于内存对象和JSON字符串的相互转换, ...
- Java实现JSONObject对象与Json字符串互相转换
Java实现JSONObject对象与Json字符串互相转换 JSONObject 转 JSON 字符串 Java代码: JSONObject jsonObject = new JSONObject( ...
- JAVA中JSON字符串格式转换
alibabab版本 即com.alibaba.fastjson *以下Node为实体类 //JSON字符串->Map Map map1 = (Map)JSON.parse(strJson); ...
- js-jquery-对象与JSON字符串互相转换
1:jQuery插件支持的转换方式 代码如下: String→Object$.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转 ...
- Json序列化与反序列化(对象与Json字符串的转换)--C#
public class JsonHelper { #region Json序列化与反序列化 /// <summary> /// 将json转化为对象 /// (需要提前构造好结构一致的M ...
随机推荐
- spring boot jar 进程自动停止,自动终止,不能后台持续运行
第一次部署spring boot 到linux上,用命令java -jar **.jar,发现应用自动退出,进程停止了.后来发现要不挂断的执行命令,忽略所有的挂断信号,用以下命令解决 nohup ja ...
- c语言中Triplet是什么意思?
此词条多出现于三元组抽象数据类型的定义. 例如: 数据结构编程试验中,构造三元组类型. 1.三元组抽象数据类型的定义 ADT Triplet { 数据对象:D={e1, e2, e3| e1, e2, ...
- MATLAB多项式及多项式拟合
多项式均表示为数组形式,数组元素为多项式降幂系数 1. polyval函数 求多项式在某一点或某几个点的值. p = [1,1,1];%x^2+x+1 x = [-1,0,1];y = po ...
- (十二)MySQL逻辑备份mysqldump
(1)简介 语法 mysqldump -h服务器 -u用户名 -p密码 [-P端口号] [参数] 数据库名 >备份文件.sql 关于数据库: -A,--all-databases 所有库,会生成 ...
- Java-事务管理
1.事务的概念: 事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部不成功. 2. 管理事务: 2.1. 数据库默认的事务 数据库默认支持事务的,但是数据库默认的事务是一条sql语 ...
- Tomcat 服务器基本知识
Tomcat下载安装和配置 下载 下载地址: http://tomcat.apache.org tomcat服务器分为很多版本, 其中包括windows版和linux版 ...
- 实例教程:1小时学会Python(转)
1 序言 面向读者 本文适合有经验的程序员尽快进入Python2.x世界.特别地,如果你掌握Java和Javascript,不用1小时你就可以用Python快速流畅地写有用的Python程序. Pyt ...
- HDU 2555 陷阱(模拟,结构体数组)
这道题目意思很明白,有不确定的数据沙包和陷阱,还要排序···那就必须要用结构体+数组 /* 在地面上有N 个大小不等的长方形陷阱,每个陷阱的周长各不相同,每个参赛者都有一个沙包,闭上眼睛把它扔向地面, ...
- hdu6059( Trie )
hdu6059 题意 给定数组 \(A\) ,问有多少对下标 \((i, j, k)\) 满足 \(i < j < k\) 且 \((A[i] \ xor \ A[j]) < (A[ ...
- 洛谷——P1163 银行贷款
P1163 银行贷款 题目描述 当一个人从银行贷款后,在一段时间内他(她)将不得不每月偿还固定的分期付款.这个问题要求计算出贷款者向银行支付的利率.假设利率按月累计. 输入输出格式 输入格式: 输入文 ...