package keiki;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
public class pro {
int maxx,maxy;
String[][] mat=new String[500][700];
String[][] data=new String[500][10];
int[] year=new int[500];
int[] month=new int[500];
String[] credit=new String[500];
String[] code=new String[500];
String[] pref=new String[500];
int s,sx;
int fastline,lastline;
int tr;
String[] code_sex=new String[500];
int p1,creditline,creditx,credity;
String rr;
public static void main(String[] args) {
pro test=new pro();
}
pro(){
maxx=100;
maxy=100;
for(tr=0;tr<6;tr++){
readxls sub2=new readxls();
sub2.maxx=maxx;
sub2.maxy=maxy;
sub2.makedata("data.xls",tr);
mat=sub2.mat;
int h;
int prefline;
prefline=0;
fastline=0;
for(s=1;s<20;s++){
for(sx=1;sx<6;sx++){
h=0;
if(mat[s][sx].indexOf("道")>-1)h=h+1;
if(mat[s+1][sx].indexOf("道")>-1)h=h+1;
if(fastline==0)h=h+1;
if(h==3)fastline=s;
if(h==3)prefline=sx;
}}
for(s=1;s<maxy+1;s++){
h=0;
if(mat[s][prefline].indexOf("沖")>-1)h=h+1;
if(mat[s][prefline].indexOf("縄")>-1)h=h+1;
if(h==2)lastline=s;
}
System.out.println(lastline+","+prefline);
creditline=0;
p1=0;
creditx=0;
credity=0;
for(s=1;s<fastline+1;s++){
for(sx=1;sx<26;sx++){
h=0;
if(mat[s][sx].indexOf("道")>-1)h=h+1;
if(mat[s][sx+1].indexOf("道")>-1)h=h+1;
if(creditx==0)h=h+1;
if(h==3)creditline=s;
if(h==3)creditx=sx;
}
}
for(sx=1;sx<70;sx++){
h=0;
if(mat[creditline][sx].indexOf("沖")>-1)h=h+1;
if(mat[creditline][sx].indexOf("縄")>-1)h=h+1;
if(h==2)credity=sx;
}
for(s=creditx;s<credity+1;s++){
credit[s]=mat[creditline][s];
}
for(s=fastline;s<lastline+1;s++){
pref[s]=mat[s][prefline];
}
if(tr==0)rr="air";
if(tr==1)rr="rail";
if(tr==2)rr="ship";
if(tr==3)rr="bus";
if(tr==4)rr="car";
if(tr==5)rr="all";
writehtml("ren.html");
System.out.println(tr);
writexml("data/"+tr+".txt");
}
}
void writexml(String file){
int s,sx;
try{
PrintWriter pw = new PrintWriter (new BufferedWriter(new FileWriter(file)));
for(s=fastline;s<lastline+1;s++){
for(sx=creditx;sx<credity+1;sx++){
pw.print("<route>");
pw.print(rr);
pw.print("</route>");
pw.print("<pref>");
pw.print(pref[s]);
pw.print("</pref>");
pw.print("<credit>");
pw.print(credit[sx]);
pw.print("</credit>");
pw.print("<value>");
pw.print(mat[s][sx]);
pw.println("</value>");
}
}
System.out.println("ファイルに書きこみました。");
pw.close();
} catch(IOException ep){ System.out.println("入出力エラーです。"); }
}
void writehtml(String file){
int s,sx;
try{
PrintWriter pw = new PrintWriter (new BufferedWriter(new FileWriter(file)));
pw.println("<html>");
pw.println("<head>");
pw.println("<meta charset=\"UTF-8\">");
pw.println("</head>");
pw.println("<body>");
pw.print("<table rules=\"all\">");
pw.print("<tr>");
pw.print("<td>");
pw.print("");
pw.print("</td>");
for(sx=1;sx<maxx+1;sx++){
pw.print("<th>");
pw.print(sx);
pw.print("</th>");
}
pw.println("</tr>");
for(s=1;s<maxy+1;s++){
pw.print("<tr>");
pw.print("<th>");
pw.print(s);
pw.print("</th>");
for(sx=1;sx<maxx+1;sx++){
pw.print("<td>");
pw.print(mat[s][sx]);
pw.print("</td>");
}
pw.println("</tr>");
}
pw.println("</table>");
pw.println("</body>");
pw.println("</html>");
System.out.println("ファイルに書きこみました。");
pw.close();
} catch(IOException ep){ System.out.println("入出力エラーです。"); }
}
}
package keiki;
import java.io.*;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.*;
public class readxls {
int maxx,maxy;
Cell cc;
String[][] mat=new String[50000][500];
int[][] color= new int[50000][500];
void makedata(String file,int number){
try{
FileInputStream is = new FileInputStream(file);
Workbook wb = new HSSFWorkbook(is);
Sheet sh = wb.getSheetAt(number);
int s,sx,j,h;
String bb;
CellStyle style = wb.createCellStyle();
for(s=1;s<maxy+1;s++){
for(sx=1;sx<maxx+1;sx++){
mat[s][sx]="";
}}
for(s=1;s<maxy+1;s++){
Row row = sh.getRow(s-1);
j=0;
if(row==null)j=100;
if(j<50){
for(sx=1;sx<maxx+1;sx++){
cc = row.getCell(sx-1);
h=0;
if(cc==null)h=100;
if(h<50){
int type =cc.getCellType();
bb="";
if(type==1)bb=cc.getStringCellValue();
if(type==0)bb=""+cc.getNumericCellValue();
short n1=cc.getCellStyle().getFillBackgroundColor();
color[s][sx]=(int)n1;
mat[s][sx]=bb;
}
}
}
}
} catch (Exception e) {e.printStackTrace();}
}
}
最終更新:2015年08月30日 18:44