第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

打開(kāi)嵌套文件結(jié)構(gòu)中引用的文件

打開(kāi)嵌套文件結(jié)構(gòu)中引用的文件

慕桂英546537 2021-03-28 13:09:33
我有一個(gè)xml文件結(jié)構(gòu),其中的主xml引用了其他一些xml文件(具有完整路徑),而其他的則引用了其他文件,依此類(lèi)推。我有很多xml文件(在一個(gè)簡(jiǎn)單的文件夾結(jié)構(gòu)中,只有一個(gè)主文件夾和3個(gè)子文件夾),但并非所有xml文件都在其他xml文件中被引用,因此,其想法是僅使用被引用的xml文件構(gòu)建一個(gè)列表。這是xml文件的非常簡(jiǎn)化的示例。main.xml非常像這樣。其他文件沒(méi)有子標(biāo)簽,因此它們是嵌套參考行的結(jié)尾。 <?xml version="1.0" encoding="UTF-8" ?> <file>   <indiv>        <name>Name Surname</name>        <birth> Oct 1826 </birth>        <death> Jan 1850 </death>           </indiv>   <children>        <chname1>Name1 Surname1</chname1>        <chcode1>F45DH3</chcode1><chdata1>C:\base\codedb\F45DH3.xml</chdata1>        <chname2>Name2 Surname2</chname2>        <chdata2>C:\base\namedb\name2sur2.xml</chdata2>   </children> </file>由于文件太多,無(wú)法手動(dòng)檢查,因此我想使用python腳本從我的主路徑開(kāi)始讀取所有文件并構(gòu)建列表。我該怎么做。到目前為止,這是我所擁有的,但是顯然這些代碼將很長(zhǎng),因?yàn)槲也恢罆?huì)找到多少級(jí)引用。任何想法?coreFile= r"C:\\base\\main.xml"xmlList = []with open(coreFile) as f:    for line in f:        if "C:\\base" in line:            start = line.find('C:\\base')            end = line.find('.xml')            path = line[start:end + 4]            if path not in xmlList:                x.append(path)                with open(path) as f2:                    for line2 in f2:                        if "C:\\base" in line2:                            start = line.find('C:\\base')                            end = line.find('.xml')                            path = line[start:end + 4]                            if path not in xmlList:                                x.append(path)                                with open(path) as f3:                                    # ...
查看完整描述

1 回答

?
慕尼黑5688855

TA貢獻(xiàn)1848條經(jīng)驗(yàn) 獲得超2個(gè)贊

所以我自己找到了答案。


萬(wàn)一它可以幫助別人,就像使用一個(gè)函數(shù)一樣簡(jiǎn)單。


請(qǐng)記住,當(dāng)并非文件夾結(jié)構(gòu)中的所有文件都在其他文件中被引用時(shí),此方法很有用,因此您需要閱讀主文件并繼續(xù)閱讀下一級(jí)的引用文件。


如果要在文件夾結(jié)構(gòu)中的所有文件中查找文件引用,請(qǐng)忽略此操作。只需讀取文件夾和子文件夾中的每個(gè)文件。


def xmlRefs(filepath):

    with open(filepath) as f:

        for line in f:

            if "C:\\base" in line:

                start = line.find('C:\\base')

                end = line.find('.xml')

                path = line[start:end + 4]


                if path not in xmlList:

                    x.append(path)

                    xmlList.append(path)

                    print path

                    xmlRefs(path)


coreFile= r"C:\\base\\main.xml"

xmlList = []

xmlRefs(coreFile)


查看完整回答
反對(duì) 回復(fù) 2021-04-13
  • 1 回答
  • 0 關(guān)注
  • 167 瀏覽
慕課專(zhuān)欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢(xún)優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)