使用postman,将excel中的车辆及电池信息,按照PDF附件中,第6大项拼装电池静态信息,发送给PDF附件中的地址

本文介绍了一种从Excel文件中读取车辆VIN及相关电池数据的方法,并使用Java将这些数据转换为实体类集合,最终序列化输出到TXT文件中。通过具体代码示例,展示了如何处理大量数据并进行有效输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

思路:

解析excel,读取vin,利用demo json用在线工具生成实体类,组装成一个集合,序列化输出到txt文件中。

程序:

package com.mtons.mblog.reach;




import com.alibaba.fastjson.JSON;
import com.mtons.mblog.BootApplication;
import com.mtons.mblog.base.utils.BeanParseException;
import com.mtons.mblog.base.utils.ExcelUtil;
import lombok.extern.slf4j.Slf4j;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.io.File;
import java.io.IOException;
import java.io.PrintStream;
import java.util.ArrayList;
import java.util.List;

@RunWith(SpringRunner.class)
@SpringBootTest(classes = BootApplication.class)
@Slf4j
public class TestCalc {

    /**
     * 可以用来读取数据
     * @throws IOException
     * @throws
     */
    @Test
    public void testAtMethod() throws IOException, BeanParseException {
        try {
            Root root = new Root();
            List<BatteryDataDTOList> batteryDataDTOSet = new ArrayList<>();
            //BatteryDataDTOList batteryDataDTOList = new BatteryDataDTOList();
            //把读到的数据写到这个文件中
            //E:\xxx 没有这个文件夹会报错
            PrintStream out = new PrintStream("D:\\reach\\reach.txt");
            //一下代码所有的system.out.println() 输出到xxx.txt文件中
            System.setOut(out);
            //文件夹路径      excel文件
            String[][] strings = ExcelUtil.readFromFile(new File("D:\\yyyy", "vin_import.xlsx"), 9, 2000);
            //r是行数
            for (int r = 1; r < strings.length; r++) {
                //这里0 1 2 列数
                //vin
                String vin = strings[r][0];
                //电池包编码
                String batteryPackageCode = strings[r][1];
                //电池模块编码
                String batteryModuleCode = strings[r][2];
                //电池单体编码 电蕊编码
                String batteryCellCode = strings[r][3];
                BatteryDataDTOList batteryDataDTOList = new BatteryDataDTOList();
                batteryDataDTOList.setVin(vin);
                batteryDataDTOList.setBatteryPackageCode(batteryPackageCode);
                batteryDataDTOList.setBatteryModuleCode(batteryModuleCode);
                batteryDataDTOList.setBatteryCellCode(batteryCellCode);
                batteryDataDTOList.setBatteryType("4");
                batteryDataDTOList.setBatteryCodeType("1");
                batteryDataDTOList.setBatteryPackageCompany("江苏时代新能源科技有限公司");
                batteryDataDTOList.setBatteryPackageVoltage("346");
                batteryDataDTOList.setBatteryPackageCapacity("177");
                if(vin.equals("LHGJ11882M8000015")){
                    batteryDataDTOList.setBatteryPackageDate("2020-04-23");
                }else if(vin.equals("LHGJ11886M8000020")){
                    batteryDataDTOList.setBatteryPackageDate("2020-05-09");
                }else if(vin.equals("LHGJ1188XM8000019")){
                    batteryDataDTOList.setBatteryPackageDate("2020-04-22");
                }else if(vin.equals("LHGJ11880M8000028")){
                    batteryDataDTOList.setBatteryPackageDate("2020-06-07");
                }else if(vin.equals("LHGJ11882M8000029")){
                    batteryDataDTOList.setBatteryPackageDate("2020-06-07");
                }

                batteryDataDTOList.setBatteryModuleVoltage("14.44");
                batteryDataDTOList.setBatteryModuleCapacity("177");
                batteryDataDTOList.setBatteryCellCompany("江苏时代新能源科技有限公司");
                batteryDataDTOList.setBatteryCellVoltage("3.61");
                batteryDataDTOList.setBatteryCellCapacity("177");
                batteryDataDTOSet.add(batteryDataDTOList);
            }
            root.setBatteryDataDTOList(batteryDataDTOSet);
            System.out.println(JSON.toJSONString(root));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static void main(String[] args) throws IOException, BeanParseException {
        new TestCalc().testAtMethod();
    }
}

输出(部分数据):

{
	"batteryDataDTOList": [{
		"batteryCellCapacity": "177",
		"batteryCellCode": "001CE280000002A4W0702153",
		"batteryCellCompany": "江苏时代新能源科技有限公司",
		"batteryCellVoltage": "3.61",
		"batteryCodeType": "1",
		"batteryModuleCapacity": "177",
		"batteryModuleCode": "001MEAHA000002A660000028",
		"batteryModuleVoltage": "14.44",
		"batteryPackageCapacity": "177",
		"batteryPackageCode": "001PEAEF000002A670300002",
		"batteryPackageCompany": "江苏时代新能源科技有限公司",
		"batteryPackageDate": "2020-06-07",
		"batteryPackageVoltage": "346",
		"batteryType": "4",
		"vin": "LHGJ11880M8000028"
	}, {
		"batteryCellCapacity": "177",
		"batteryCellCode": "001CE280000002A4W0702058",
		"batteryCellCompany": "江苏时代新能源科技有限公司",
		"batteryCellVoltage": "3.61",
		"batteryCodeType": "1",
		"batteryModuleCapacity": "177",
		"batteryModuleCode": "001MEAHA000002A660000028",
		"batteryModuleVoltage": "14.44",
		"batteryPackageCapacity": "177",
		"batteryPackageCode": "001PEAEF000002A670300002",
		"batteryPackageCompany": "江苏时代新能源科技有限公司",
		"batteryPackageDate": "2020-06-07",
		"batteryPackageVoltage": "346",
		"batteryType": "4",
		"vin": "LHGJ11880M8000028"
	}]
}

返回:

{
    "code": "0",
    "message": "OK",
    "data": "",
    "recordsFiltered": 0,
    "recordsTotal": 0
}

参考博客:

https://blog.csdn.net/yunfengfengfeng/article/details/106207159

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值