Scala操作外部数据
Scala操作外部数据:
1、操作文件
2、操作XML
3、操作MySQL
读取文件:
object FileApp {
def main(args: Array[String]): Unit = {
//system file
val file = Source.fromFile("Users/rocky/imooc/hello.txt") (scala.io.Codec.UTF8)
def readLine(): Unit = {
for(line <- file.getLines()) { //一行一行的读取
println(line)
}
}
readLine()
//URL
def readNet(): Unit = {
val file = Source.fromURL("http://www.baidu.com")
for(line <- file.getLines()) { //一行一行的读取
println(line)
}
}
}
}
在配置文件里引入mysql的依赖:
<dependcency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.45</version>
</dependcency>
操作MySQL数据库:
object MySQLApp extends App {
val url = "jdbc:mysql://localhost:3306/mysql"
val username = "root"
val password = "root"
var connection:Connection = null
try{
// make the connection
classOf[com.mysql.jdbc.Driver]
//拿到连接
val connection = DriverManager.getConnection(url, username, password)
//create the statement, and run the select query
val statement = connection.createStatement()
val resultSet = statement.executeQuery("select host,user from user")
while(resultSet.next()){
val host = resultSet.getString("host")
val user = resultSet.getString("user")
println(s"$host, $user")
} catch {
case e:Exception => e.printStackTrace()
} finally {
//free
if(connection == null) {
connection.close()
}
}
}
}
操作XML文件:
object XMLApp extends App {
//loadXML()
readXMLAttr()
//第一种方式:load(ClassPath)
def loadXML(): Unit = {
//val xml = XML.load(this.getClass.getClassLoader.getResource("test.xml"))
//println(xml)
//第二种方式:load(is: InputStream)
//val xml = XML.load(new FileInputStream("/Users/rocky/source/scala-train/src/main/resources/test.xml"))
//第三种方式:load(reader)
//val xml = XML.load(new InputStreamReader(new FileInputStream("/Users/rocky/source/scala-train/src/main/resources/test.xml"))
}
//读取XML文件里的字段的值
def readXMLAttr(): Unit = {
val xml = XML.load(this.getClass.getClassLoader.getResource("PK.xml"))
//header/field
val headerField = xml \ "header" \ "field"
println(headerField)
//all field
val fields = xml \\ "field"
for (field <- fields) {
println(field)
}
//header/field/name
//val filedAttributes = (xml \ "header" \ "field").map(_ \ "@name")
val filedAttributes = (xml \ "header" \ "field" \\ "@name")
for (filedAttribute <- filedAttributes) {
println(filedAttribute)
}
//name="Logon" message
//val filters = (xml \\ "message").filter(_.attribute("name").exists(_.text.equals("Logon")))
val filters = (xml \\ "message").filter(x => ((x \ "@name").text).equals("Logon"))
for (filter <- filters) {
println(filter)
}
// header/field/name content
(xml \ "header" \ "field").map(x => (x \ "@name", x.text, x \ "@required")) .foreach(println)
}
}
Scala操作外部数据的更多相关文章
- Scala学习——操作外部数据
scala操作外部数据 一.scala读取文件及网络数据 package top.ruandb.scala.Course08 import scala.io.Source object FileApp ...
- 快速入门Python中文件读写IO是如何来操作外部数据的?
读写文件是最常见的IO操作.Python内置了读写文件的函数,用法和C是兼容的. 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘, ...
- Catalyst揭秘 Day8 Final 外部数据源和缓存系统
Catalyst揭秘 Day8 Final 外部数据源和缓存系统 今天是Catalyst部分的收官,主要讲一些杂项内容. 外部数据源处理 什么叫外部数据源,是SparkSql自己支持的一些文件格式,以 ...
- 【翻译】Flink 异步I / O访问外部数据
本文来自官网翻译: Asynchronous I/O for External Data Access 需要异步I / O操作 先决条件 异步I / O API 超时处理 结果顺序 活动时间 容错保证 ...
- geotrellis使用(五)使用scala操作Accumulo
要想搞明白Geotrellis的数据处理情况,首先要弄清楚数据的存放,Geotrellis将数据存放在Accumulo中. Accumulo是一个分布式的Key Value型NOSQL数据库,官网为( ...
- STM32学习笔记(八) SPI总线(操作外部flash)
1. SPI总线简介 SPI全称串行外设接口,是一种高速,全双工,同步的外设总线:它工作在主从方式,常规需要至少4根线才能够正常工作.SPI作为基本的外设接口,在FLASH,EPPROM和一些数字通讯 ...
- 找呀志_ContentResolver操作ContentProvider数据
当需要外部的应用ContentProvider该数据被添加.删.修改和查询操作.可以使用ContentResolver 类完成 要得到ContentResolver 物,可以使用Activity提供g ...
- Postman高级应用——流程控制、调试、公共函数、外部数据文件
postman客户端下载地址:https://www.getpostman.com/apps 目录 流程控制 调试 公共函数 外部数据文件 流程控制 流程控制简言之就是设置接口的执行顺序,流程控制只有 ...
- R学习笔记(4): 使用外部数据
来源于:R学习笔记(4): 使用外部数据 博客:心内求法 鉴于内存的非持久性和容量限制,一个有效的数据处理工具必须能够使用外部数据:能够从外部获取大量的数据,也能够将处理结果保存.R中提供了一系列的函 ...
随机推荐
- SQL server 关于 GROUP BY 详细讲解和用法
1. Group By 语句简介: Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”.它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若 ...
- V8引擎回收机制、 内存泄露
一.垃圾回收:将内存不在使用的数据进行清理,释放内存空间 v8将内存分为新生代空间和老生代的空间 新生代空间:用于存活较短的对象 :又分为二个空间:from空间和to空间 :Scav ...
- Sql server 启用调试
在SQL Server 2008管理平台上,调试2005的数据库,会报错. 用 SQL Server 2008管理平台,调试本机数据库,当登录服务器名为“.”的时候也会报错. 解决方法,暂时使用S ...
- 常见3种Git服务器的构建
学习Git不同的服务器形式,具体如下: - 创建SSH协议服务器 - 创建Git协议服务器 - 创建HTTP协议服务器 方案: Git支持很多服务器协议形式,不同协议的Git服务器,客户端就可以使用不 ...
- 11JSP基础
1.Jsp基础 1.1 简介 Jsp,全称 Java Server Page java服务页面,能提供java服务的页面 jsp vs html html: 由html标签组成的,输出静态内容. js ...
- nginx 重写
rewrite指令可在 server 块或者 location 块中配置. 语法: rewrite regex replacement [flag]; 1.rewrite 接收的 uri 不包含 ho ...
- 前端每日实战:21# 视频演示如何用纯 CSS 创作文本滑动特效的 UI 界面
效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/QrxxaW 可交互视频教程 此视频 ...
- kafka 磁盘写满导致 InternalError
tailf kafka/log/server.log [2019-12-19 17:19:05,121] FATAL (main kafka.server.KafkaServerStartable 1 ...
- OC中保存自定义类型对象的持久化方法
OC中如果要将自定义类型的对象保存到文件中,必须进行以下三个条件: 想要把存放自定义类型的数组进行 持久化(就是将内存中的临时数据以文件<数据库等>的形式写到磁盘上)必须满足: 1. 自定 ...
- web应用,http协议简介,web框架
一.web应用 web应用程序是一种可以通过Web访问的应用程序,程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件.应用程序有两种模式C/S.B/S.C/S是客户端 ...