使用Scanner将InputStream类型转换成String
我们在测试项目中经常会遇到这样的情形:
1. 从文件或网络得到一个InputStream,需要转换成String赋值到别的变量做为另一个方法的入参。
2. 从文件或网络得到一个InputStream后,需要查看得到的InputStream是不是我们所需要的。
下面主要分析如何使用Scanner来处理。
从 JDK 5.0 开始,基本类库中增加了java.util.Scanner类,使用它的Scanner(InputStream source)构造方法,可以传入InputStream,通过它提供的next()方法;查找并返回来自此扫描器的下一个完整标记。完整标记的前后是与分隔模式匹配的输入信息,默认使用空格作为分割符来分隔文本,可以自定义分隔符。
下面是一个简单的例子:
从文件c:/test.txt读取输入流,传入scanner对象,通过next(方法)查找字符串文本,然后打印字符串文本。这样我们就成功的完成了转换。
public static void main(String[] args) throws IOException {
InputStream inputStream = new FileInputStream("c:/test.txt");
Scanner scanner = new Scanner(inputStream, "UTF-8");
String sc = scanner.next();
System.out.println(sc);
scanner.close();
}
上面代码是默认使用空格作为分割符来分隔文本,也可以自己定义分隔符,比如我们用逗号“,”作为分隔符。那么输入流中逗号以后的内容都不会传给sc了。
public static void main(String[] args) throws IOException {
InputStream inputStream = new FileInputStream("c:/test.txt");
Scanner scanner = new Scanner(inputStream, "UTF-8");
String sc = scanner.useDelimiter(",").next();
System.out.println(sc);
scanner.close();
}
下面将知识拓展一下,
以上的输入流是来自文件,那么要是输入流来自console呢?
public static void main(String[] args) throws IOException {
Scanner scanner = new Scanner(System.in, "UTF-8");
String sc = scanner.useDelimiter(",").next();
System.out.println(sc);
scanner.close();
}
输入abc edf wefw,weew,few
输出:abc edf wefw
我们可以看到逗号的文本都没有打印,这是因为next() 方法遇见第一个有效字符(非空格,换行符)时,开始扫描,当遇见第一个分隔符或结束符(空格或换行符)时,结束扫描。
我们再来看看nextLine()方法,nextline()是以回车作为结束标志,它是可以得到带空格的字符串的.
public static void main(String[] args) throws IOException {
Scanner scanner = new Scanner(System.in, "UTF-8");
String sc = scanner.useDelimiter(",").nextLine();
System.out.println(sc);
scanner.close();
}
输入abc edf wefw,weew,few
输出abc edf wefw,weew,few
需要注意的是,如果输入流是文件,那么nextLine()方法将只返回文件的第一行。
使用Scanner将InputStream类型转换成String的更多相关文章
- Java 把 InputStream 转换成 String 的几种方法
我们在 Java 中经常会碰到如何把 InputStream 转换成 String 的情形,比如从文件或网络得到一个 InputStream,需要转换成字符串输出或赋给别的变量. 未真正关注这个问题之 ...
- Java 里把 InputStream 转换成 String 的几种方法
我们在 Java 中经常会碰到如何把 InputStream 转换成 String 的情形,比如从文件或网络得到一个 InputStream,需要转换成字符串输出或赋给别的变量. 未真正关注这个问题之 ...
- oracle Clob类型转换成String类型
转载:https://www.cnblogs.com/itmyhome/p/4131339.html Clob类型转换成String类型 oracle中表结构如下: create table GRID ...
- Clob类型转换成String类型
oracle中表结构如下: create table GRID_RESOURCE ( ID VARCHAR2(50), CNNAME VARCHAR2(50), TYPE VARCHAR2(50), ...
- oracle.sql.Clob类型转换成String类型
方法一: public String ClobToString(Clob clob) throws SQLException, IOException { String reString = &quo ...
- 如何将Object类型转换成String类型
1. Object.toString() obj.toString() 注意:必须保证Object不是null值,否则将抛出NullPointerException异常. 2. (String)Obj ...
- int类型转换成String , 不足n位 在前面补0
1.String.format("%02d", 5);-->结果:05 0代表前面要补的字符 2代表字符串长度 d表示参数为整数类型 2.秒转换成时分秒 private St ...
- Java中Clob类型转换成String类型的问题
1.问题: 项目中使用druid+达梦数据库(基本类似Oracle),查出的Clob类型数据在运行时为ClobProxyImpl对象而不是内容,不能转为字符串 2.原代码: map为达梦数据库或Ora ...
- Java,double类型转换成String,String装换成double型
今天,老师布置了小系统,银行用户管理系统,突然发现自己的基础知识好薄弱,就把这些记录一下, double类型转化string:Double.toString(double doub); String类 ...
随机推荐
- PHP框架中.htaccess文件作用
1..htaccess文件使用前提 .htaccess的主要作用就是实现url改写,也就是当浏览器通过url访问到服务器某个文件夹时,作为主人,我们可以来接待这个url,具体地怎样接待它,就是此文件的 ...
- mysql 查询近几天的结果 按每天的粒度查询
),DATE_FORMAT(FROM_UNIXTIME(createtime), '%Y-%m-%d') as time from bskuser group by time
- css美化checkbox
- MYSQL数据库索引类型及使用
MYSQL数据库索引类型包括普通索引,唯一索引,主键索引与组合索引,这里对这些索引的做一些简单描述: (1)普通索引 这是最基本的MySQL数据库索引,它没有任何限制.它有以下几种创建方式: 创建索引 ...
- Selenium_Python接口-Alert类
Alert类的路径:from selenium.webdriver.common.alert import Alert Alert类主要是一些对弹出框的操作,如:获取属性.确认.取消等 接口内容: f ...
- 【PHP系列】框架的抉择
缘起 在PHP开发中,选择合适的框架有助于加快软件开发,节约宝贵的项目时间,让开发者专注于功能的实现上.框架的问题是需要很多的投入,选择框架时,我们更看重这个框架的未来,存在多年的大型框架必须要有好的 ...
- DevExpress控件使用之多重坐标图形的绘制 z
有时候,基于对一些年份.月份的统计,需要集成多个数值指标进行分析,因此就需要把多种数据放到一个图形里面展现,也成为多重坐标轴,多重坐标轴可以是多个X轴,也可以是Y轴,它们的处理方式类似.本文通过一个例 ...
- C#中的多线程 - 并行编程 z
原文:http://www.albahari.com/threading/part5.aspx 专题:C#中的多线程 1并行编程Permalink 在这一部分,我们讨论 Framework 4.0 加 ...
- python IO 文件读写
IO 由于CPU和内存的速度远远高于外设的速度,所以,在IO编程中,就存在速度严重不匹配的问题. 如要把100M的数据写入磁盘,CPU输出100M的数据只需要0.01秒,可是磁盘要接收这100M数据可 ...
- DBMS_SQLTUNE使用方法
SQL调优工具包DBMS_SQLTUNE的使用方法 oracle 提供了优化建议功能包DBMS_SQLTUNE,该包可以帮助我们分析SQL,并提供优化建议. 原有执行计划alter session s ...