中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java怎么將Excel數據轉化為樹形結構

發布時間:2023-05-08 11:50:40 來源:億速云 閱讀:199 作者:zzz 欄目:編程語言

本文小編為大家詳細介紹“Java怎么將Excel數據轉化為樹形結構”,內容詳細,步驟清晰,細節處理妥當,希望這篇“Java怎么將Excel數據轉化為樹形結構”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。

前言

今天收到一個導入的任務,要求將excel數據保存到數據庫中,不同于普通的導入,這個導入的數據是一個樹形結構,如下圖:

Java怎么將Excel數據轉化為樹形結構

通過觀察數據中的層級列我們發現表格數據由2棵樹組成,分別是第3,4,5,6,7,8,9,10,11和12,13,14,15,16,17,18,它們由0作樹的根節點,1為0的子節點,2為相鄰1的子節點,由此得出第一顆樹的結構為:

Java怎么將Excel數據轉化為樹形結構

拆分原始數據

1.創建實體類

創建vo接收解析數據,在這里,我們只關心層級屬性

	@Excel(name = "層級")
    private String hierarchy;
    @Excel(name = "物料編碼")
    private String materialCode;
    @Excel(name = "物料名稱")
    private String materialName;
    @Excel(name = "基礎數量")
    private BigDecimal materialNum;
    @Excel(name = "使用數量")
    private BigDecimal useAmount;
    @Excel(name = "BOM版本")
    private String version;
    @Excel(name = "默認BOM")
    private String isDefaults;
2.處理數據

將數據源拆分為若干棵樹的數據集

代碼如下(示例):

/**
     * 將集合對象按指定元素分割存儲
     *
     * @param materialVos 原始集合
     * @param s 分割元素(這里是當集合對象層級為0時則分割,也就是樹的根節點為0)
     * @return 每棵樹的結果集
     */
    private List<List<MatMaterialBomImportVo>> subsection(List<MatMaterialBomImportVo> materialVos, String s) {
        List<List<MatMaterialBomImportVo>> segmentedData = new ArrayList<>();
        if (materialVos != null) {
            //獲取指定元素的數量,判斷出最終將拆分為多少段
            List<MatMaterialBomImportVo> collect = materialVos.stream().filter(bom -> s.equals(bom.getHierarchy())).collect(Collectors.toList());
            int count = 0;
            for (int i = 0; i < collect.size(); i++) {
                List<MatMaterialBomImportVo> bomImportVo = new ArrayList<>();
                boolean num = false;
                //遍歷數據源
                for (; count < materialVos.size(); count++) {
                    //第一個必然為樹的根節點,直接獲取并跳過
                    if (count == 0) {
                        bomImportVo.add(materialVos.get(count));
                        continue;
                    }
                    //當數據源第n個等于根節點并且已經成功添加過數據時判斷為一段數據的結束,跳出循環,
                    if (s.equals(materialVos.get(count).getHierarchy()) && num) {
                        break;
                    }
                    bomImportVo.add(materialVos.get(count));
                    num = true;
                }
                segmentedData.add(bomImportVo);
            }
        }
        return segmentedData;
    }

手動設置每棵樹每個節點的id以及父id

代碼如下(示例):

for (List<MatMaterialBomImportVo> segmentedDatum : subsection(materialVos, "0")) {
                //設置id以及父id
                int i = 0;
                for (MatMaterialBomImportVo vo : segmentedDatum) {
                    BeanTrim.beanAttributeValueTrim(vo);
                    vo.setPrimaryKey(i);
                    getParentId(vo, segmentedDatum);
                    i++;
                }
}
/**
     * 設置父id
     *
     * @param vo
     * @param segmentedDatum
     */
    private void getParentId(MatMaterialBomImportVo vo, List<MatMaterialBomImportVo> segmentedDatum) {
        for (int j = vo.getPrimaryKey(); j >= 0; j--) {
            if (Integer.parseInt(segmentedDatum.get(j).getHierarchy()) == Integer.parseInt(vo.getHierarchy()) - 1) {
                vo.setForeignKey(segmentedDatum.get(j).getPrimaryKey());
                break;
            }
            if (j == 0) {
                vo.setForeignKey(-1);
            }
        }
    }

說明:拆分為若干棵樹后設置每條數據的虛擬id為自己的索引,每棵樹的id互相隔離,

根據表格數據規律得出子節點只可能存在于自己節點以下,以及下一個相同節地以上,根據這個規律設置每個節點的父id

遞歸封裝為樹結構

代碼如下(示例):

/**
     * 遞歸遍歷為樹形結構
     *
     * @param vo 當前處理的元素
     * @param segmentedDatum 每棵樹的數據集
     */
    private void treeData(MatMaterialBomImportVo vo, List<MatMaterialBomImportVo> segmentedDatum) {
        for (int i = vo.getPrimaryKey(); i < segmentedDatum.size(); i++) {
            if (i + 1 == segmentedDatum.size()) {
                if (vo.getForeignKey() == null) {
                    getParentId(vo, segmentedDatum);
                }
                break;
            }
            int v = Integer.parseInt(vo.getHierarchy());
            int vs = Integer.parseInt(segmentedDatum.get(i + 1).getHierarchy());
            if (vs == v + 1) {
                if (v > 1) {
                    vo.setForeignKey(segmentedDatum.get(i).getPrimaryKey());
                    for (int j = vo.getPrimaryKey(); j > 0; j--) {
                        if (Integer.parseInt(segmentedDatum.get(j).getHierarchy()) == Integer.parseInt(vo.getHierarchy()) - 1) {
                            vo.setForeignKey(segmentedDatum.get(j).getPrimaryKey());
                        }
                    }
                }
                vo.getImportVoList().add(segmentedDatum.get(i + 1));
            }
            if (vs <= v) {
                if (vo.getForeignKey() == null) {
                    for (int j = vo.getPrimaryKey(); j > 0; j--) {
                        if (Integer.parseInt(segmentedDatum.get(j).getHierarchy()) == Integer.parseInt(vo.getHierarchy()) - 1) {
                            vo.setForeignKey(segmentedDatum.get(j).getPrimaryKey());
                            break;
                        }
                    }
                }
                break;
            }
        }
        if (vo.getImportVoList() != null && vo.getImportVoList().size() > 0) {
            for (MatMaterialBomImportVo matMaterialBomImportVo : vo.getImportVoList()) {
                treeData(matMaterialBomImportVo, segmentedDatum);
            }
        }
    }

說明:我這里傳進來的vo是沒有設置id和父id的,只對數據源做了樹拆分處理,因為業務需求,后面并沒有使用這套遞歸的方法組裝為樹,所以遞歸代碼可能有點誤差,僅供參考。

讀到這里,這篇“Java怎么將Excel數據轉化為樹形結構”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乳山市| 华亭县| 武鸣县| 搜索| 漾濞| 凤台县| 确山县| 晋宁县| 白玉县| 梅州市| 嘉荫县| 天气| 文昌市| 阳朔县| 岳阳市| 尚志市| 普格县| 富阳市| 姚安县| 金寨县| 巴楚县| 广灵县| 南陵县| 资阳市| 承德市| 仪征市| 政和县| 光泽县| 木兰县| 营口市| 来凤县| 金乡县| 开平市| 吉安县| 巨野县| 镇赉县| 朝阳县| 太湖县| 历史| 玉溪市| 林周县|