annotate tools/parse.scala @ 1:cdfc5e2de435

Checking in our problem set and a simple scala parser
author Joshua Garnett <josh.garnett@gmail.com>
date Thu, 08 Aug 2013 21:08:01 -0400
parents
children 5cf8de487ed6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
1 //
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
2 // How to run: scala -cp json-smart-1.0.9-1.jar parse.scala
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
3 //
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
4 import net.minidev.json._
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
5 import scala.collection.JavaConversions._
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
6 import scala.collection.mutable._
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
7
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
8 val file = scala.io.Source.fromFile("../data/myproblems.json").mkString
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
9 val json = JSONValue.parse(file).asInstanceOf[JSONArray]
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
10
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
11 var totalProblems = json.size
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
12 var totalSize = 0
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
13 val operatorHash = HashMap[String, Int]()
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
14
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
15 for(p <- json) {
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
16 val problem = p.asInstanceOf[JSONObject]
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
17 totalSize += problem.get("size").asInstanceOf[java.lang.Integer]
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
18 val operators = problem.get("operators").asInstanceOf[JSONArray]
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
19 for(o <- operators) {
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
20 val operator = o.asInstanceOf[String]
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
21 operatorHash(operator) = operatorHash.get(operator) match {
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
22 case Some(count) => count + 1
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
23 case None => 1
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
24 }
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
25 }
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
26 }
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
27
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
28 println("Total problems: " + totalProblems)
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
29 println("Total size: " + totalSize)
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
30 println("Average size: " + totalSize / totalProblems)
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
31
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
32 println("Operator Count: ")
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
33 for((key, value) <- operatorHash) {
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
34 println(" " + key + ":" + value)
cdfc5e2de435 Checking in our problem set and a simple scala parser
Joshua Garnett <josh.garnett@gmail.com>
parents:
diff changeset
35 }