所以我想掃描大型XML文件(40MB),而據我瞭解,我應該使用的NSXMLParser,以減少內存佔用。我想檢查每首歌的情況,如果它通過了所有條件,請將歌曲寫入新的XML文件。解析iTunes資料庫XML可可
我可以用的NSXMLParser加載並執行文件的一些基本的閱讀。所以我想知道如何將每首歌曲保存爲臨時變量?什麼樣的對象應該被保存爲(我假設可變的東西,所以我可以繼續添加更多的歌曲到文件之前,我把它寫入文件)。
<key>Tracks</key>
<dict>
<key>11072</key>
<dict>
<key>Track ID</key><integer>1107</integer>
<key>Name</key><string>Kids with Guns (Hot Chip Remix)</string>
<key>Artist</key><string>Gorillaz</string>
<key>Album</key><string>D-Sides</string>
<key>Genre</key><string>Britpop</string>
<key>Kind</key><string>MPEG audio file</string>
<key>Size</key><integer>844299</integer>
<key>Total Time</key><integer>42971</integer>
<key>Disc Number</key><integer>2</integer>
<key>Disc Count</key><integer>2</integer>
<key>Track Number</key><integer>6</integer>
<key>Track Count</key><integer>9</integer>
<key>Year</key><integer>2007</integer>
<key>Date Modified</key><date>2008-10-30T02:44:58Z</date>
<key>Date Added</key><date>2007-12-25T21:54:16Z</date>
<key>Bit Rate</key><integer>153</integer>
<key>Sample Rate</key><integer>44100</integer>
<key>Comments</key><string> __FIXED__U74A0ECA</string>
<key>Play Count</key><integer>1</integer>
<key>Play Date</key><integer>3292750639</integer>
<key>Play Date UTC</key><date>2008-05-04T20:57:19Z</date>
<key>Skip Count</key><integer>1</integer>
<key>Skip Date</key><date>2008-02-09T06:17:30Z</date>
<key>Artwork Count</key><integer>2</integer>
<key>Persistent ID</key><string>74A0ECAC8D</string>
<key>Track Type</key><string>File</string>
<key>Location</key><string>file://xxxxx/x/iTunes/Music/Gorillaz/D-Sides/2-06%20Kids%20with%20Guns%20(Hot%20Chip%20Remix).mp3</string>
<key>File Folder Count</key><integer>5</integer>
<key>Library Folder Count</key><integer>1</integer>
</dict>
澄清。我想創建一個新的.xml文件(比如在我的桌面上)。使用原始XML文件中的一些歌曲。 截至目前我只是保存信息到一個臨時的字典,但其創造的字典中相同的格式origonal XML的新文件(我的桌面上)的問題林。 – urbanrider
你有什麼問題?編寫XML比閱讀更容易,所以爲什麼你有困難?如果你問一個關於這些問題的完全不同的問題,也許會更好。請注意,XML不會輕鬆,直接地完全轉換爲任何對象類型,所以如果您只是爲了編寫XML而閱讀XML,那麼最好不要使用臨時變量:只是將所有內容都維持在「頭腦中」作爲XML整個時間。 – matt