java读取xml配置文件实现Excel表格批量导入

public static void main(String[] args) {
        BatchImportUtils batchImportUtils = new BatchImportUtils();
        List<Map<String, String>> mapList = batchImportUtils.uploadExcel("D:\\resources\\123.xls", "D:\\resources\\new.xml", null);
        //如果遇到错误只返回一条信息
        if(mapList.size()<2){
            String message = mapList.get(0).get("message");
            System.out.println(message);
        }else {

        }
        System.exit(0);
    }
public List<Map<String,String>> uploadExcel(String excelFilePath,String xmlFilePath , HttpServletRequest request){

        List<Map<String,String>> mapList = new ArrayList<>();
        try {
            DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
            DocumentBuilder db = factory.newDocumentBuilder();
            // 创建一个Document对象
            Document doc = db.parse(xmlFilePath);
            //获取第一级菜单集合
            NodeList chartsList = doc.getElementsByTagName("Table");
            //遍历导入Excel文件
            File importFile = new File(excelFilePath);
            //读取文件流
            InputStream reanIn = null;

            if (!importFile.isDirectory()) {
                //如果是文件
                reanIn = new FileInputStream(imp
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面是实现Vue中的Excel表格批量导入功能,并携带公共的模型id的步骤: 1. 安装`xlsx`和`file-saver`库 ```bash npm install xlsx file-saver --save ``` 2. 创建一个Excel表格导入组件 ```vue <template> <div> <input type="file" ref="file" @change="importExcel" /> </div> </template> <script> import XLSX from 'xlsx' import { saveAs } from 'file-saver' export default { props: { modelId: { type: String, required: true } }, methods: { importExcel(e) { const files = e.target.files const promises = [] for (let i = 0; i < files.length; i++) { const file = files[i] const promise = new Promise((resolve, reject) => { const reader = new FileReader() reader.onload = (event) => { const data = event.target.result const workbook = XLSX.read(data, { type: 'binary' }) const worksheet = workbook.Sheets[workbook.SheetNames[0]] const json = XLSX.utils.sheet_to_json(worksheet, { header: 1 }) // 发送请求,并携带公共的模型id // ... resolve() } reader.readAsBinaryString(file) }) promises.push(promise) } Promise.all(promises).then(() => { // 所有文件导入完成后的回调 }) } } } </script> ``` 3. 在`importExcel`方法中,使用`FileReader`读取Excel表格文件,并使用`XLSX`库解析数据。然后,您可以将解析后的数据发送到后端,同时携带公共的模型id。注意,这里使用了Promise.all来处理多个文件导入。 4. 在父组件中使用Excel表格导入组件,并向其传递公共的模型id。 ```vue <template> <div> <excel-import :model-id="modelId" /> </div> </template> <script> import ExcelImport from './ExcelImport.vue' export default { components: { ExcelImport }, data() { return { modelId: '123456' // 公共的模型id } } } </script> ``` 这样,您就可以在Vue中实现Excel表格批量导入功能,并携带公共的模型id。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值