懒惰地解析非常大的xml

Har*_*dya 9 scala xml-parsing

我有一个巨大的xml文件(40 gbs).我想从中提取一些字段而不将整个文件加载到内存中.有什么建议?

Arj*_*jan 22

与XMLEventReader的一个简单的例子基于对SAXParser的教程在这里(如发表的Rinat Tainov).

我确信它可以做得更好但只是为了显示基本用法:

import scala.io.Source
import scala.xml.pull._

object Main extends App {
  val xml = new XMLEventReader(Source.fromFile("test.xml"))

  def printText(text: String, currNode: List[String]) {
    currNode match {
      case List("firstname", "staff", "company") => println("First Name: " + text)
      case List("lastname", "staff", "company") => println("Last Name: " + text)
      case List("nickname", "staff", "company") => println("Nick Name: " + text)
      case List("salary", "staff", "company") => println("Salary: " + text)
      case _ => ()
    }
  }

  def parse(xml: XMLEventReader) {
    def loop(currNode: List[String]) {
      if (xml.hasNext) {
        xml.next match {
          case EvElemStart(_, label, _, _) =>
            println("Start element: " + label)
            loop(label :: currNode)
          case EvElemEnd(_, label) =>
            println("End element: " + label)
            loop(currNode.tail)
          case EvText(text) =>
            printText(text, currNode)
            loop(currNode)
          case _ => loop(currNode)
        }
      }
    }
    loop(List.empty)
  }

  parse(xml)
}
Run Code Online (Sandbox Code Playgroud)