JAVA获取系统中的变量

本文介绍如何利用Java编程语言通过System类获取系统中的变量,包括环境变量和系统属性,并将这些变量信息整理成Excel文件进行保存。通过使用POI库,实现了变量信息的读取和导出功能,方便后续查询和管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过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();
		}
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值