JAVA获取系统中的变量

通过System类可以获取系统中的变量。可以获取env和System Property。获取到之后存到D盘的SystemProperties.xls中。具体需要用到什么系统变量以后就可以在这个xls中查询了。

程序需要用到POI,我的版本是3.10。如果没有的话可以在这下载:poi_3.10_FINAL

不想使用POI的童鞋吧for循环里面的代码改成System.out.println();输出即可。

import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Properties;
import java.util.Set;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.util.CellRangeAddress;


public class TestJava {
	static Map<String , String> env = System.getenv();
	static Map<String , String> properties = new HashMap<String , String>();
	public static void main(String[] args) {
		/*
		 * Get properties in System and write to XLS File
		 */
		File file = new File("D:/SystemProperties.xls");
		if (file.exists()) {
			file.delete();
		}
		Workbook wb = null;
		OutputStream os = null;
		try {
			file.createNewFile();
			os = new FileOutputStream(file);
			wb = new HSSFWorkbook();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		} 
		Sheet sheet = wb.createSheet("env");
		CellRangeAddress cra = new CellRangeAddress(0,0,0,1);
		sheet.addMergedRegion(cra);
		Row row = sheet.createRow(0);
		row.createCell(0).setCellValue("env");
		row = sheet.createRow(1);
		row.createCell(0).setCellValue("Name");
		row.createCell(1).setCellValue("Value");
		int rownum=2;
		Set<Entry<String, String>>  set = env.entrySet();		
		for (Entry<String, String> entry : set) {
			row = sheet.createRow(rownum);
			row.createCell(0).setCellValue(entry.getKey());
			row.createCell(1).setCellValue(entry.getValue());
			rownum++;
		}
		sheet = wb.createSheet("SystemProperties");
		sheet.addMergedRegion(cra);
		row = sheet.createRow(0);
		row.createCell(0).setCellValue("SystemProperties");
		row = sheet.createRow(1);
		row.createCell(0).setCellValue("Name");
		row.createCell(1).setCellValue("Value");;
		Properties p = System.getProperties();
		Set<String> names =  p.stringPropertyNames();
		rownum=2;
		for (String name : names) {
			row = sheet.getRow(rownum);
			if (row == null) {
				row = sheet.createRow(rownum);
			}
			row.createCell(0).setCellValue(name);
			row.createCell(1).setCellValue(p.getProperty(name));
			rownum++;
		}
		try {
			wb.write(os);
			os.close();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值