技术标签: Properties类简介 Properties使用 Properties类常用方法 Properties Java基础知识
Properties 继承于 Hashtable。表示一个持久的属性集,属性列表以key-value的形式存在,key和value都是字符串。
Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置。像Python支持的配置文件是.ini文件,同样,它也有自己读取配置文件的类ConfigParse,方便程序员或用户通过该类的方法来修改.ini配置文件。在Java中,其配置文件常为.properties文件,格式为文本文件,文件的内容的格式是“键=值”的格式,文本注释信息可以用"#"来注释。
除了从Hashtable中所定义的方法,Properties定义了以下方法:
返回值类型 | 方法和描述 |
---|---|
String |
getProperty(String key) 搜索具有此属性列表中的指定键属性。 |
String |
getProperty(String key, String defaultValue) 搜索具有此属性列表中的指定键属性。 |
void |
list(PrintStream out) 将此属性列表输出到指定的输出流。 |
void |
list(PrintWriter out) 将此属性列表输出到指定的输出流。 |
void |
load(InputStream inStream) 从输入的字节流中读取属性列表 (键和元素对)。 |
void |
load(Reader reader) 属性列表 (键和元素对) 从流中读取的输入的字符在一个简单的面向行的格式。 |
void |
loadFromXML(InputStream in) 加载所有到此属性表所指定的输入流的 XML 文档表示的属性。 |
Enumeration<?> |
propertyNames() 在此属性列表中,如果具有相同名称的密钥不已发现从主要属性列表中的默认属性列表中包括非重复键返回所有键的枚举。 |
void |
save(OutputStream out, String comments) 弃用。 如果发生 I/O 错误,则保存在属性列表中,此方法不会引发时抛出。保存的属性列表的首选的方法是通过 store(OutputStream out, String comments) 方法或 storeToXML(OutputStream os, String comment) 方法。 |
Object |
setProperty(String key, String value) 调用 Hashtable 方法 put 。 |
void |
store(OutputStream out, String comments) 此属性列表 (键和元素对) 此 Properties 表中写入输出流中适合装载到 Properties 表中使用 load(InputStream) 方法的格式。 |
void |
store(Writer writer, String comments) 此属性列表 (键和元素对) 此 Properties 表中写入输出字符流格式适合使用 load(Reader) 方法。 |
void |
storeToXML(OutputStream os, String comment) 发出代表所有包含此表中的属性的 XML 文档。 |
void |
storeToXML(OutputStream os, String comment, String encoding) 发出代表所有包含在此表中,使用指定的编码的属性的 XML 文档。 |
Set<String> |
stringPropertyNames() 返回一组键此属性列表中的关键和其对应的值都是字符串,默认属性列表中包括非重复键,如果具有相同名称的密钥不已发现从主要属性列表。 |
Properties类
下面我们从写入、读取、遍历等角度来解析Properties类的常见用法
项目路径如下
src
main
java
com
jourwon
prop
PropertiesTest
resources
config.properties
prop.properties
PropertiesTest为测试类,prop.properties文件的内容如下
username=root
password=123456
Properties类调用setProperty方法将键值对保存到内存中,此时可以通过getProperty方法读取,propertyNames方法进行遍历,但是并没有将键值对持久化到属性文件中,故需要调用store方法持久化键值对到属性文件中。
public static void main(String[] args) throws IOException {
Properties properties = new Properties();
OutputStream output = null;
try {
output = new FileOutputStream("src/main/resources/config.properties");
properties.setProperty("username", "root");
properties.setProperty("password", "123456");
// 保存键值对到文件中
properties.store(output, "JourWon modify");
} catch (IOException io) {
io.printStackTrace();
} finally {
if (output != null) {
try {
output.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
输出结果,在resources目录下多一个文件config.properties,内容如下
#JourWon modify
#Mon Sep 09 14:23:44 CST 2019
password=123456
username=root
下面给出常见的六种读取properties文件的方式:
public static void main(String[] args) throws IOException {
// PropertiesTest.getPath1();
// PropertiesTest.getPath2();
// PropertiesTest.getPath3();
// PropertiesTest.getPath4();
// PropertiesTest.getPath5();
PropertiesTest.getPath6();
}
/**
* 一、 使用java.util.Properties类的load(InputStream in)方法加载properties文件
* 主要是需要加上src这个文件夹名。路径配置需要精确到绝对地址级别
*
* @return
*/
public static void getPath1() throws IOException {
InputStream in = new BufferedInputStream(new FileInputStream(
new File("src/main/resources/prop.properties")));
printKeyValue(in);
}
/**
* 二、 使用java.util.ResourceBundle类的getBundle()方法
* 注意:这个getBundle()方法的参数只能写成包路径+properties文件名,注意不需要带上后缀名。
*
* @return
*/
public static void getPath2() {
ResourceBundle rb = ResourceBundle
.getBundle("prop");
printKeyValueRb(rb);
}
/**
* 三、 使用java.util.PropertyResourceBundle类的构造函数
*
* @return
*/
public static void getPath3() throws IOException {
InputStream in = new BufferedInputStream(new FileInputStream("src/main/resources/prop.properties"));
ResourceBundle rb = new PropertyResourceBundle(in);
printKeyValueRb(rb);
}
/**
* 四、 使用class变量的getResourceAsStream()方法
* 注意:getResourceAsStream()方法的参数按格式写到包路径+properties文件名+.后缀
*
* @return
*/
public static void getPath4() throws IOException {
InputStream in = PropertiesTest.class
.getResourceAsStream("/prop.properties");
printKeyValue(in);
}
/**
* 五、
* 使用class.getClassLoader()所得到的java.lang.ClassLoader的
* getResourceAsStream()方法
* getResourceAsStream(name)方法的参数必须是包路径+文件名+.后缀
* 否则会报空指针异常
*
* @return
*/
public static void getPath5() throws IOException {
InputStream in = PropertiesTest.class.getClassLoader()
.getResourceAsStream("./././prop.properties");
printKeyValue(in);
}
/**
* 六、 使用java.lang.ClassLoader类的getSystemResourceAsStream()静态方法
* getSystemResourceAsStream()方法的参数格式也是有固定要求的
*
* @return
*/
public static void getPath6() throws IOException {
InputStream in = ClassLoader
.getSystemResourceAsStream("./././prop.properties");
printKeyValue(in);
}
/**
* 单独抽取的方法,用户检测能否正确操纵Properties
*
* @param inputStream
* @throws IOException
*/
public static void printKeyValue(InputStream inputStream) throws IOException {
Properties properties = new Properties();
properties.load(inputStream);
Set<Object> keys = properties.keySet();
for (Object key : keys) {
System.out.println(key + " = " + properties.get(key));
}
if (inputStream != null) {
inputStream.close();
}
}
public static void printKeyValueRb(ResourceBundle rb) {
Set<String> keys = rb.keySet();
for (String key : keys) {
System.out.println(key + " = " + rb.getString(key));
}
}
输出结果都是
password = 123456
username = root
其中第一、四、五、六种方式都是先获得文件的输入流,然后通过Properties类的load(InputStream inStream)方法加载到Properties对象中,最后通过Properties对象来操作文件内容。
第二、三中方式是通过ResourceBundle类来加载Properties文件,然后ResourceBundle对象来操做properties文件内容。
其中最重要的就是每种方式加载文件时,文件的路径需要按照方法的定义的格式来加载,否则会抛出各种异常,比如空指针异常。
下面给出四种遍历Properties中的所有键值对的方法:
/**
* 输出properties的key和value
*/
public static void printProp(Properties properties) {
System.out.println("---------(方式一)------------");
for (String key : properties.stringPropertyNames()) {
System.out.println(key + "=" + properties.getProperty(key));
}
System.out.println("---------(方式二)------------");
//返回属性key的集合
Set<Object> keys = properties.keySet();
for (Object key : keys) {
System.out.println(key.toString() + "=" + properties.get(key));
}
System.out.println("---------(方式三)------------");
Set<Map.Entry<Object, Object>> entrySet = properties.entrySet();
//返回的属性键值对实体
for (Map.Entry<Object, Object> entry : entrySet) {
System.out.println(entry.getKey() + "=" + entry.getValue());
}
System.out.println("---------(方式四)------------");
Enumeration<?> e = properties.propertyNames();
while (e.hasMoreElements()) {
String key = (String) e.nextElement();
String value = properties.getProperty(key);
System.out.println(key + "=" + value);
}
}
文章浏览阅读2.6k次,点赞6次,收藏31次。API 接口文档:API Reference:https://miyakogi.github.io/pyppeteer/reference.html pyppeteergithub 地址:https://github.com/miyakogi/pyppeteer pyppeteer英文文档地址:https://miyakogi.github.i..._pyppeteer
文章浏览阅读170次。@IT程序猿 微博网友评论:@余音袅袅Lena:还有老师站后面看着改bug@月小夕__:我司程序员深有体会@倉優小子:设计师应该感受更深吧@梦中醒不过来:别的架构师 vs..._一编程室友就在旁边看
文章浏览阅读151次。原文地址:https://www.linuxidc.com/Linux/2018-07/153129.htminit是Linux系统操作中不可缺少的程序之一。init进程,它是一个由内核启动的用户级进程。内核会在过去曾使用过init的几个地方查找它,它的正确位置(对Linux系统来说)是/sbin/init。如果内核找不到init,它就会试着运行/bin/sh,如果运行失败,系统的启动也会失败。..._linux的几个运行级别运行界面截图
文章浏览阅读1.5w次,点赞9次,收藏26次。解决 idea maven依赖引入失效,无法正常导入依赖问题idea是真的好用,不过里面的maven依赖问题有时候还真挺让人头疼,不少小伙伴也许会遇到刚配好不久的maven突然就无法正常导入依赖了,或者正满怀激情地看着教学视频想跟着敲一波代码,最后却因依赖无法导入而激情湮灭;又或者开发了挺久的项目哪天敲着敲着代码就一片爆红,一顿猛操作却发现是依赖失效了!又或者诸如…等等。关键是最后试了下网上常用的套路:1.右键 pom.xml -> maven -> reimport;2.File -&g_idea maven失效
文章浏览阅读1k次。import mathimport randomfrom random import sampleimport numpy as npfrom numpy import *import geatpy as eaimport xlrd##已知数据q1='F:\共享车选址调度\共享汽车数据\候选点之间的OD(13).xlsx'T1='F:\共享车选址调度\共享汽车数据\候选点之间的..._遗传算法中最优个体是什么
文章浏览阅读1.1k次。先来看一下微信支付的流程,可见在整个支付流程中后台需要处理的事情有:1、调用统一下单api2、生成JSAPI页面调用的支付参数,并请求支付3、异步通知商户支付结果4、返回微信异步通知的处理结果下面来实际编程实现以上的过程,这里面我们使用了第三方Sdk,best-pay-sdkhttps://github.com/Pay-Group/best-pay-sdkmaven引入依赖 ..._cn.springboot.bestpay
文章浏览阅读259次。git错误:fatal: unable to access 'https://github.com/baidu/amis.git/': OpenSSL SSL_read: Connection was reset, errno 10054产生原因:一般是这是因为服务器的SSL证书没有经过第三方机构的签署,所以才报错解决办法:解除ssl验证后,再次git即可 git config --global http.sslVerify "false"...
文章浏览阅读3.2k次。1.加入相关依赖: packaging>presto-plugin</packaging> <!--设置presto版本--> <properties> <presto.verison>0.208</presto.verison> </propertie..._presto调用聚合函数的步骤
文章浏览阅读3.3k次,点赞11次,收藏6次。容器退出后,通过 docker container ls 命令查看不到,数据会丢失么?如何停止所有正在运行的容器?如何批量清理已经停止的容器?如何获取某个容器的 PID 信息?如何给容器指定一个固定 IP 地址?如何临时退出一个正在交互的容器的终端,而不终止它?使用 docker port 命令映射容器的端口时,系统报错“Error: No public port ‘80’ published for xxx”?_docker container run停止以后容器消失
文章浏览阅读10w+次,点赞28次,收藏41次。花了4个小时就为装这个玩样,终于解决了,真的又气又兴奋(笑死)。不知道是版本问题还是什么,我在自己电脑上使用pip install SciencePlots安装,只能安装1.0.1版本,但是这个版本根本没有效果,用不了。然后我又使用手动安装si在了一个细节上,坑太多了。我的开发环境:Anaconda python3.6官方地址(其实SciencePlots是matplotlib样式包,是给定了几个学术作图的样式)SciencePlots · PyPIFormat Matplotlib_scienceplots安装
文章浏览阅读2.3k次。数据预处理是指在对数据进行数据挖掘之前,先对原始数据进行必要的清洗、集成、转换、离散和规约等一系列的处理工作,已达到挖掘算法进行知识获取研究所要求的最低规范和标准。通常数据预处理包括:数据清洗、数据集成、数据变换、数据规约。一:数据清洗数据清洗是填充缺失数据、消除噪声数据等操作,主要通过分析“脏数据”的产生原因和存在形式,利用现有的数据挖掘手段和方法去清洗“脏数据”,将“脏数据”转化为满足数据质量..._python数据预处理
文章浏览阅读96次。原标题:机型正式确认,鸿蒙OS 2.0第一批名单曝光!花粉:华为不够厚道最新消息:华为的鸿蒙OS2.0暂定在12月18日开放Beta测试版本,明年一二月份将面向部分手机用户提供升级渠道(机型下方公布),与此同时,华为方面表示,市面上百分之九十的华为机型都可以升级鸿蒙。 鸿蒙姗姗来迟从去年开始,中国的手机用户就在期待华为自家的手机操作系统,鸿蒙OS已经不只是简简单单的代表一个自研的操作系统了,它更..._鸿蒙开放批次