首页 > 其他 > 详细

获取Excel部分数据并很据项目要求计算适宜性等级综合指数判断该地区的土壤适宜性

时间:2014-07-14 09:54:38      阅读:438      评论:0      收藏:0      [点我收藏+]

代码运行前请先导入jxl架包,以下代码仅供学习参考:

下图为项目中的Excel

bubuko.com,布布扣

 

bubuko.com,布布扣

 

ExcelTest02类代码如下:

 

// 读取Excel的类
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;

public class ExcelTest02 {
       /*
         *该代码需要先获得excel里面的pH、有机质、氯含量和质地等值
         *然后根据公式IAI(pH)=PH×权重(pH)计算出各个的IAI然后相加
         *根据IAI(总)的值判断该地图土壤是否适宜种植烟草
         */

	static double IAI1;
	static double IAI2;
	static double IAI3;
	static double IAI4;
	static double IAI5;

	public static void main(String args[]) {
		try {
			System.out.println("begini");
			Workbook book = Workbook.getWorkbook(new File("a.xls"));
			// 获得第一个工作表对象
			Sheet sheet = book.getSheet(0);
			// 得到第一列第一行的单元格

			try {
				File file = new File("d:/IAI.txt");
				if (file.exists()) {
					file.delete();
				}
				file.createNewFile();
				BufferedWriter output = new BufferedWriter(new FileWriter(file));

				for (int i = 2; i < 4896; i++) {
					Cell cell1 = sheet.getCell(23, i);// PH
					Cell cell2 = sheet.getCell(24, i);// 有机质
					Cell cell3 = sheet.getCell(33, i);// 氯含量
					Cell cell4 = sheet.getCell(22, i);// 质地

					Cell cell5 = sheet.getCell(4, i);// 省
					Cell cell6 = sheet.getCell(7, i);// 县
					Cell cell7 = sheet.getCell(8, i);// 乡
					Cell cell8 = sheet.getCell(9, i);// 村
					Cell cell9 = sheet.getCell(10, i);// 组

					String ph = cell1.getContents();
					double phWeight = 0.1235;
					computePhValue(TypeConversion(ph), phWeight);

					String youjizhi = cell2.getContents();
					double youjizhiWeight = 0.2075;
					computeYoujizhiValue(TypeConversion(youjizhi),
							youjizhiWeight);

					String lv = cell3.getContents();
					double lvWeight = 0.1112;
					computeLvValue(TypeConversion(lv), lvWeight);

					String zhidi = cell4.getContents();
					double zhidiWeight = 0.3057;
					computeZhidiValue(zhidi, zhidiWeight);

					double houduWeight = 0.2521;
					houdu(houduWeight);

					String sheng = cell5.getContents();
					String xian = cell6.getContents();
					String xiang = cell7.getContents();
					String cun = cell8.getContents();
					String zu = cell9.getContents();

					String shiyixing = null;
					double IAI = IAI1 + IAI2 + IAI3 + IAI4 + IAI5;
					if (IAI < 70.0) {
						shiyixing = "不适宜";
					}
					if (IAI >= 70.0 && IAI < 80.0) {
						shiyixing = "次适宜";
					}
					if (IAI >= 80.0 && IAI < 88.0) {
						shiyixing = "适宜";
					}
					if (IAI >= 88.0) {
						shiyixing = "最适宜";
					}

					System.out.println("第" + (i + 1) + "行"
							+ (IAI1 + IAI2 + IAI3 + IAI4 + IAI5));
					output.write("第" + (i + 1) + "行" + sheng + xian + xiang
							+ cun + zu + "\t" + "IAI:"
							+ (IAI1 + IAI2 + IAI3 + IAI4 + IAI5) + "\t"
							+ shiyixing + "\n");
					output.newLine();
				}
				output.close();
			} catch (Exception ex) {
				System.out.println(ex);
			}
			book.close();
			System.out.println("end");
		} catch (Exception e) {
			System.out.println(e);
		}
	}

	/**
	 * 
	 * @param
	 * @return
	 */
	public static double computePhValue(double ph, double phWeight) {
		double result = 0d;
		if (ph == 0) {
			return result;
		}

		if (ph < 4.5) {
			IAI1 = 60.00 * phWeight;
		}
		if (ph == 4.5) {
			IAI1 = 68.75 * phWeight;
		}
		if (ph > 4.5 && ph < 5.0) {
			IAI1 = (30 * ph - 66.25) * phWeight;
		}
		if (ph == 5.0) {
			IAI1 = 83.75 * phWeight;
		}
		if (ph > 5.0 && ph < 5.5) {
			IAI1 = (32.5 * ph - 78.75) * phWeight;
		}
		if (ph == 5.5 || (ph > 5.5 && ph < 6.5) || ph == 6.5) {
			IAI1 = 100 * phWeight;
		}
		if (ph > 6.5 && ph < 7.0) {
			IAI1 = (-16.24 * ph + 205.56) * phWeight;
		}
		if (ph == 7.0) {
			IAI1 = 91.88 * phWeight;
		}
		if (ph > 7.0 && ph < 7.5) {
			IAI1 = (-23.76 * ph + 258.2) * phWeight;
		}
		if (ph == 7.5) {
			IAI1 = 80.00 * phWeight;
		}
		if (ph > 7.5 && ph < 8.0) {
			IAI1 = (-77.14 * ph + 658.55) * phWeight;
		}
		if (ph == 8.0) {
			IAI1 = 41.43 * phWeight;
		}
		if (ph > 8.0) {
			IAI1 = 8.75 * phWeight;
		}
		return result;
	}

	public static double computeYoujizhiValue(double youjizhi,
			double youjizhiWeight) {
		double result = 0d;
		if (youjizhi == 0) {
			return result;
		}

		if (youjizhi < 10) {
			IAI2 = 58.75 * youjizhiWeight;
		}
		if (youjizhi > 10 && youjizhi < 15) {
			IAI2 = (4.37 * youjizhi + 15.05) * youjizhiWeight;
		}
		if (youjizhi == 15) {
			IAI2 = 80.60 * youjizhiWeight;
		}
		if (youjizhi > 15 && youjizhi < 20) {
			IAI2 = (2 * youjizhi + 50.6) * youjizhiWeight;
		}
		if (youjizhi == 20) {
			IAI2 = 90.60 * youjizhiWeight;
		}
		if (youjizhi > 20 && youjizhi < 25) {
			IAI2 = (1.88 * youjizhi + 53) * youjizhiWeight;
		}
		if (youjizhi == 25) {
			IAI2 = 100 * youjizhiWeight;
		}
		if (youjizhi > 25 && youjizhi < 30) {
			IAI2 = (2.12 * youjizhi + 47) * youjizhiWeight;
		}
		if (youjizhi == 30) {
			IAI2 = 89.40 * youjizhiWeight;
		}
		if (youjizhi > 30 && youjizhi < 35) {
			IAI2 = (-2.5 * youjizhi + 164.4) * youjizhiWeight;
		}
		if (youjizhi == 35) {
			IAI2 = 76.90 * youjizhiWeight;
		}
		if (youjizhi > 35 && youjizhi < 40) {
			IAI2 = (-3.38 * youjizhi + 195.2) * youjizhiWeight;
		}
		if (youjizhi == 40) {
			IAI2 = 60.00 * youjizhiWeight;
		}
		if (youjizhi > 40) {
			IAI2 = 48.8 * youjizhiWeight;
		}
		return result;
	}

	public static double computeLvValue(double lv, double lvWeight) {
		double result = 0d;
		if (lv == 0) {
			return result;
		}
		if (lv == 5) {
			IAI3 = 87.50 * lvWeight;
		}
		if (lv > 5 && lv < 10) {
			IAI3 = (2.5 * lv + 75) * lvWeight;
		}
		if (lv == 10) {
			IAI3 = 100 * lvWeight;
		}
		if (lv > 10 && lv < 20) {
			IAI3 = (-0.625 * lv + 106.25) * lvWeight;
		}
		if (lv == 20) {
			IAI3 = 93.75 * lvWeight;
		}
		if (lv > 20 && lv < 30) {
			IAI3 = (-1.625 * lv + 126.25) * lvWeight;
		}
		if (lv == 30) {
			IAI3 = 77.50 * lvWeight;
		}
		if (lv > 30 && lv < 40) {
			IAI3 = (-1.25 * lv + 115) * lvWeight;
		}
		if (lv == 40) {
			IAI3 = 65.00 * lvWeight;
		}
		if (lv > 40 && lv < 50) {
			IAI3 = (-6.5 * lv + 325) * lvWeight;
		}
		if (lv > 50) {
			IAI3 = 0;
		}
		return result;
	}

	public static void computeZhidiValue(String zhidi, double zhidiWeight) {
		if ("沙土".equals(zhidi)) {
			IAI4 = 91.40 * zhidiWeight;
		}
		if ("壤沙土".equals(zhidi)) {
			IAI4 = 100 * zhidiWeight;
		}
		if ("沙壤土".equals(zhidi)) {
			IAI4 = 100 * zhidiWeight;
		}
		if ("壤土".equals(zhidi)) {
			IAI4 = 91.40 * zhidiWeight;
		}
		if ("粉沙壤土".equals(zhidi)) {
			IAI4 = 82.10 * zhidiWeight;
		}
		if ("粘壤土".equals(zhidi)) {
			IAI4 = 72.10 * zhidiWeight;
		}
		if ("粘土".equals(zhidi)) {
			IAI4 = 48.50 * zhidiWeight;
		}
	}

       //由于土层厚度在给出的数据里面并没有,这里选随机数
	public static void houdu(double houduWeight) {
		int len = 5;
		int lens = 5;
		double sum = 0;
		int[] houdu = new int[len];
		double[] IAI5s = new double[lens];

		for (int i = 0; i < len; i++) {
			houdu[i] = (int) (Math.random() * 70 + 20);

			for (int j = 0; j < lens; j++) {
				if (houdu[j] < 20) {
					IAI5s[j] = 32.85 * houduWeight;
				}
				if (houdu[j] > 20 && houdu[j] < 30) {
					IAI5s[j] = (1.855 * houdu[j] - 4.25) * houduWeight;
				}
				if (houdu[j] == 30) {
					IAI5s[j] = 51.40 * houduWeight;
				}
				if (houdu[j] > 30 && houdu[j] < 50) {
					IAI5s[j] = (1.18 * houdu[j] + 16) * houduWeight;
				}
				if (houdu[j] == 50) {
					IAI5s[j] = 75.00 * houduWeight;
				}
				if (houdu[j] > 50 && houdu[j] < 70) {
					IAI5s[j] = (0.715 * houdu[j] + 39.25) * houduWeight;
				}
				if (houdu[j] == 70) {
					IAI5s[j] = 89.30 * houduWeight;
				}
				if (houdu[j] > 70) {
					IAI5s[j] = 100 * houduWeight;
				}
			}
			sum = sum + IAI5s[i];
			IAI5 = sum / 5;
		}
	}

	public static double TypeConversion(String value) {
		double values = 0;
		if (value != "") {
			values = Double.parseDouble(value.trim());
		} else {
			values = 0;
		}
		return values;
	}
}            

 

 

运行结果如下图所示:

bubuko.com,布布扣

 

 

生成的文本内容如下:

bubuko.com,布布扣

 

 

注意下:由于没有土层厚度的数据,所以在程序中采用了随机数选取几组数据求平均值,故每次生成的文本内容都不一样

 

获取Excel部分数据并很据项目要求计算适宜性等级综合指数判断该地区的土壤适宜性,布布扣,bubuko.com

获取Excel部分数据并很据项目要求计算适宜性等级综合指数判断该地区的土壤适宜性

原文:http://www.cnblogs.com/henuyuxiang/p/3837596.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!