中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)

本文小編為大家詳細(xì)介紹“Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

創(chuàng)新互聯(lián)作為成都網(wǎng)站建設(shè)公司,專(zhuān)注重慶網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì),有關(guān)企業(yè)網(wǎng)站建設(shè)方案、改版、費(fèi)用等問(wèn)題,行業(yè)涉及混凝土泵車(chē)等多個(gè)領(lǐng)域,已為上千家企業(yè)服務(wù),得到了客戶(hù)的尊重與認(rèn)可。

前言

今天收到一個(gè)導(dǎo)入的任務(wù),要求將excel數(shù)據(jù)保存到數(shù)據(jù)庫(kù)中,不同于普通的導(dǎo)入,這個(gè)導(dǎo)入的數(shù)據(jù)是一個(gè)樹(shù)形結(jié)構(gòu),如下圖:

Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)

通過(guò)觀察數(shù)據(jù)中的層級(jí)列我們發(fā)現(xiàn)表格數(shù)據(jù)由2棵樹(shù)組成,分別是第3,4,5,6,7,8,9,10,11和12,13,14,15,16,17,18,它們由0作樹(shù)的根節(jié)點(diǎn),1為0的子節(jié)點(diǎn),2為相鄰1的子節(jié)點(diǎn),由此得出第一顆樹(shù)的結(jié)構(gòu)為:

Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)

拆分原始數(shù)據(jù)

1.創(chuàng)建實(shí)體類(lèi)

創(chuàng)建vo接收解析數(shù)據(jù),在這里,我們只關(guān)心層級(jí)屬性

	@Excel(name = "層級(jí)")
    private String hierarchy;
    @Excel(name = "物料編碼")
    private String materialCode;
    @Excel(name = "物料名稱(chēng)")
    private String materialName;
    @Excel(name = "基礎(chǔ)數(shù)量")
    private BigDecimal materialNum;
    @Excel(name = "使用數(shù)量")
    private BigDecimal useAmount;
    @Excel(name = "BOM版本")
    private String version;
    @Excel(name = "默認(rèn)BOM")
    private String isDefaults;
2.處理數(shù)據(jù)

將數(shù)據(jù)源拆分為若干棵樹(shù)的數(shù)據(jù)集

代碼如下(示例):

/**
     * 將集合對(duì)象按指定元素分割存儲(chǔ)
     *
     * @param materialVos 原始集合
     * @param s 分割元素(這里是當(dāng)集合對(duì)象層級(jí)為0時(shí)則分割,也就是樹(shù)的根節(jié)點(diǎn)為0)
     * @return 每棵樹(shù)的結(jié)果集
     */
    private List<List<MatMaterialBomImportVo>> subsection(List<MatMaterialBomImportVo> materialVos, String s) {
        List<List<MatMaterialBomImportVo>> segmentedData = new ArrayList<>();
        if (materialVos != null) {
            //獲取指定元素的數(shù)量,判斷出最終將拆分為多少段
            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;
                //遍歷數(shù)據(jù)源
                for (; count < materialVos.size(); count++) {
                    //第一個(gè)必然為樹(shù)的根節(jié)點(diǎn),直接獲取并跳過(guò)
                    if (count == 0) {
                        bomImportVo.add(materialVos.get(count));
                        continue;
                    }
                    //當(dāng)數(shù)據(jù)源第n個(gè)等于根節(jié)點(diǎn)并且已經(jīng)成功添加過(guò)數(shù)據(jù)時(shí)判斷為一段數(shù)據(jù)的結(jié)束,跳出循環(huán),
                    if (s.equals(materialVos.get(count).getHierarchy()) && num) {
                        break;
                    }
                    bomImportVo.add(materialVos.get(count));
                    num = true;
                }
                segmentedData.add(bomImportVo);
            }
        }
        return segmentedData;
    }

手動(dòng)設(shè)置每棵樹(shù)每個(gè)節(jié)點(diǎn)的id以及父id

代碼如下(示例):

for (List<MatMaterialBomImportVo> segmentedDatum : subsection(materialVos, "0")) {
                //設(shè)置id以及父id
                int i = 0;
                for (MatMaterialBomImportVo vo : segmentedDatum) {
                    BeanTrim.beanAttributeValueTrim(vo);
                    vo.setPrimaryKey(i);
                    getParentId(vo, segmentedDatum);
                    i++;
                }
}
/**
     * 設(shè)置父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);
            }
        }
    }

說(shuō)明:拆分為若干棵樹(shù)后設(shè)置每條數(shù)據(jù)的虛擬id為自己的索引,每棵樹(shù)的id互相隔離,

根據(jù)表格數(shù)據(jù)規(guī)律得出子節(jié)點(diǎn)只可能存在于自己節(jié)點(diǎn)以下,以及下一個(gè)相同節(jié)地以上,根據(jù)這個(gè)規(guī)律設(shè)置每個(gè)節(jié)點(diǎn)的父id

遞歸封裝為樹(shù)結(jié)構(gòu)

代碼如下(示例):

/**
     * 遞歸遍歷為樹(shù)形結(jié)構(gòu)
     *
     * @param vo 當(dāng)前處理的元素
     * @param segmentedDatum 每棵樹(shù)的數(shù)據(jù)集
     */
    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);
            }
        }
    }

說(shuō)明:我這里傳進(jìn)來(lái)的vo是沒(méi)有設(shè)置id和父id的,只對(duì)數(shù)據(jù)源做了樹(shù)拆分處理,因?yàn)闃I(yè)務(wù)需求,后面并沒(méi)有使用這套遞歸的方法組裝為樹(shù),所以遞歸代碼可能有點(diǎn)誤差,僅供參考。

讀到這里,這篇“Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站欄目:Java怎么將Excel數(shù)據(jù)轉(zhuǎn)化為樹(shù)形結(jié)構(gòu)
標(biāo)題鏈接:http://www.rwnh.cn/article14/psjdde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁(yè)設(shè)計(jì)公司、微信公眾號(hào)微信小程序、定制開(kāi)發(fā)、網(wǎng)站制作關(guān)鍵詞優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管
长兴县| 永清县| 肃南| 准格尔旗| 平度市| 璧山县| 墨江| 梅州市| 富宁县| 斗六市| 淳安县| 柳林县| 灵川县| 得荣县| 吉木萨尔县| 曲松县| 渝北区| 灌南县| 牙克石市| 綦江县| 育儿| 平安县| 乐都县| 潍坊市| 沭阳县| 深州市| 牡丹江市| 兰西县| 黎平县| 昭苏县| 濮阳县| 乌兰浩特市| 琼结县| 深圳市| 台安县| 泌阳县| 柘荣县| 连州市| 巨鹿县| 沐川县| 鄯善县|