找回密码
 立即注册→加入我们

QQ登录

只需一步,快速开始

搜索
热搜: 下载 VB C 实现 编写
查看: 6409|回复: 3

用爬虫获取医院信息

[复制链接]
发表于 2014-4-6 14:24:28 | 显示全部楼层 |阅读模式

欢迎访问技术宅的结界,请注册或者登录吧。

您需要 登录 才可以下载或查看,没有账号?立即注册→加入我们

×
    由于项目需要,人手又不够,不可能自己从江苏省人民医院里一个个提取信息做网页放到自己的网站中。这里就是程序设计的精髓了,程序就是用来解决大量的重复的劳动的,如果你能手动实现某过程的一个细节,且这些细节具有相似性,那么你就可以很容易用程序做出。

还是用jsoup。运行以后会获得300M的数据,包括处理过的图像和生成的xml,医生信息和科室信息,直接上代码了,自己写了有400行,效果在后面。
jsph.java

  1. package jsph;

  2. import java.io.BufferedWriter;
  3. import java.io.File;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import java.io.InputStream;
  7. import java.io.OutputStreamWriter;
  8. import java.io.UnsupportedEncodingException;
  9. import java.io.Writer;
  10. import java.net.URL;
  11. import java.net.URLConnection;

  12. import org.jsoup.Jsoup;
  13. import org.jsoup.nodes.Document;
  14. import org.jsoup.nodes.Element;
  15. import org.jsoup.nodes.Node;
  16. import org.jsoup.select.Elements;

  17. public class jsph
  18. {
  19.         private String keshijieshao="http://www.jsph.net/col/col25/index.html";
  20.         private String[] names={"内科","外科","老年医学科","康复医学科","妇产科","儿科","门急诊","医技"};
  21.         private String[] addrs=
  22.         {
  23.                 "http://www.jsph.net/col/col861/index.html",
  24.                 "http://www.jsph.net/col/col862/index.html",
  25.                 "http://www.jsph.net/col/col863/index.html",
  26.                 "http://www.jsph.net/col/col864/index.html",
  27.                 "http://www.jsph.net/col/col865/index.html",
  28.                 "http://www.jsph.net/col/col866/index.html",
  29.                 "http://www.jsph.net/col/col867/index.html",
  30.                 "http://www.jsph.net/col/col868/index.html",
  31.         };
  32.         
  33.         private String url="http://www.jsph.net/script/0/nav.js";
  34.         private int threadnum=0;
  35.         
  36.         public jsph()
  37.         {
  38.                 try
  39.                 {
  40.                         Document keshidoc=Jsoup.connect(keshijieshao).timeout(0).get();
  41.                         processKeshi(keshidoc.select("a[style=font-size:14px;]"));
  42.                         Elements doctorlist=new Elements();
  43.                         
  44.                         int i,j;
  45.                         for(i=0;i<names.length;i++)
  46.                         {
  47.                                 Document doc=Jsoup.connect(addrs[i]).timeout(0).get();
  48.                                 Elements eles=doc.select("td[width=752]").get(0).children();
  49.                                 for(j=11;j<eles.size();j+=3)
  50.                                 {
  51.                                         doctorlist.addAll(eles.get(j).select("a"));
  52.                                 }                                
  53.                         }
  54.                         processYisheng(doctorlist);
  55.                 }
  56.                 catch (Exception e)
  57.                 {
  58.                         e.printStackTrace();
  59.                 }
  60.         }
  61.         
  62.         public String c(String src) throws Exception
  63.         {
  64. //                return src;
  65.                 return new String(src.getBytes(),"gb2312");
  66.         }
  67.         
  68.         public void processKeshi(Elements eles) throws Exception
  69.         {
  70.                 FileOutputStream fos=new FileOutputStream("重点专科.xml");
  71.                 OutputStreamWriter osw=new OutputStreamWriter(fos,"UTF-8");
  72.                 BufferedWriter bw=new BufferedWriter(osw);
  73.                 bw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  74.                 bw.write(c("<keshis>\n"));
  75.                 bw.write(c("\t<keshi>\n"));
  76.                 bw.write(c("\t\t<name>内科</name>\n"));
  77.                 bw.write(c("\t\t<id></id>\n"));
  78.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  79.                 bw.write(c("\t</keshi>\n"));
  80.                
  81.                 bw.write(c("\t<keshi>\n"));
  82.                 bw.write(c("\t\t<name>外科</name>\n"));
  83.                 bw.write(c("\t\t<id></id>\n"));
  84.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  85.                 bw.write(c("\t</keshi>\n"));        
  86.                
  87.                 bw.write(c("\t<keshi>\n"));
  88.                 bw.write(c("\t\t<name>内科</name>\n"));
  89.                 bw.write(c("\t\t<id></id>\n"));
  90.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  91.                 bw.write(c("\t</keshi>\n"));
  92.                
  93.                 bw.write(c("\t<keshi>\n"));
  94.                 bw.write(c("\t\t<name>老年病学科</name>\n"));
  95.                 bw.write(c("\t\t<id>13</id>\n"));
  96.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  97.                 bw.write(c("\t</keshi>\n"));
  98.                
  99.                 bw.write(c("\t<keshi>\n"));
  100.                 bw.write(c("\t\t<name>康复医学科</name>\n"));
  101.                 bw.write(c("\t\t<summary>江苏省人民医院康复医学科成立于1956年,55年来学科发展迅速,目前已成立了康复医学中心。"
  102.                                 + "现有康复门诊800平方米,病房76张床位、盛泽分院康复医学科22张床位,江苏省人民医院康复医学分院是国内三级甲等"
  103.                                 + "医院中临床规模最大、设备最齐全、技术实力最强的科室之一</summary>\n"));
  104.                 bw.write(c("\t\t<detailurl>康复医学科.htm</detailurl>\n"));
  105.                 bw.write(c("\t\t<id>37</id>\n"));
  106.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  107.                 bw.write(c("\t</keshi>\n"));
  108.                
  109.                 bw.write(c("\t<keshi>\n"));
  110.                 bw.write(c("\t\t<name>妇产科</name>\n"));
  111.                 bw.write(c("\t\t<id></id>\n"));
  112.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  113.                 bw.write(c("\t</keshi>\n"));
  114.         
  115.                 bw.write(c("\t<keshi>\n"));
  116.                 bw.write(c("\t\t<name>儿科</name>\n"));
  117.                 bw.write(c("\t\t<id>28</id>\n"));
  118.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  119.                 bw.write(c("\t</keshi>\n"));
  120.                
  121.                 bw.write(c("\t<keshi>\n"));
  122.                 bw.write(c("\t\t<name>门急诊</name>\n"));
  123.                 bw.write(c("\t\t<id></id>\n"));
  124.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  125.                 bw.write(c("\t</keshi>\n"));
  126.                
  127.                 bw.write(c("\t<keshi>\n"));
  128.                 bw.write(c("\t\t<name>医技</name>\n"));
  129.                 bw.write(c("\t\t<id></id>\n"));
  130.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  131.                 bw.write(c("\t</keshi>\n"));
  132.                
  133.                 String fatherkeshiname="";
  134.                 for(int i=0;i<eles.size();i++)
  135.                 {
  136.                         Document curdoc=Jsoup.connect(eles.get(i).attr("abs:href")).timeout(0).get();
  137.                         Elements temp1=curdoc.select("a[style=color:#0053a3;]");
  138.                         String curfather=temp1.get(temp1.size()-2).text();
  139.                         System.out.println("father:"+curfather);
  140.                         if(i == 0)
  141.                         {
  142.                                 bw.write(c("\t<"+curfather+">\n"));
  143.                                 fatherkeshiname=curfather;
  144.                         }
  145.                         else if(!fatherkeshiname.equals(curfather))
  146.                         {
  147.                                 bw.write(c("\t</"+fatherkeshiname+">\n"));
  148.                                 fatherkeshiname=curfather;
  149.                                 bw.write(c("\t<"+fatherkeshiname+">\n"));
  150.                         }
  151.                         
  152.                         bw.write(c("\t\t<keshi>\n"));
  153.                         bw.write(c("\t\t\t<name>"+eles.get(i).text()+"</name>\n"));
  154.                         System.out.println(eles.get(i).text());
  155.                         bw.write(c("\t\t\t<id></id>\n"));
  156.                         Elements inner=curdoc.select("td[style=padding:0px 10px 0px 10px;]\n");
  157.                         bw.write(c("\t\t\t<summary>"+getProperText(inner.text())+"</summary>\n"));
  158.                         String keshiname=eles.get(i).text();
  159.                         bw.write(c("\t\t\t<detailurl>"+keshiname+".htm</detailurl>\n"));
  160.                         bw.write(c("\t\t</keshi>\n"));
  161.                         
  162.                         if(i == eles.size()-1)
  163.                         {
  164.                                 bw.write(c("\t</"+curfather+">\n"));
  165.                         }
  166.                         
  167.                         FileOutputStream infos=new FileOutputStream(keshiname+".htm");
  168.                         OutputStreamWriter inosw=new OutputStreamWriter(infos,"UTF-8");
  169.                         BufferedWriter inbw=new BufferedWriter(inosw);
  170.                         inbw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  171.                         inbw.write(c("<!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">\n"));
  172.                         inbw.write(c("<html xmlns="http://www.w3.org/1999/xhtml">\n"));
  173.                         inbw.write(c("<head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>"+keshiname+"</title></head>\n"));
  174.                         inbw.write(c("<body>\n\t<div>\n"));
  175.                         if(inner.select("a").size() != 0)
  176.                         {
  177.                                 Document detailpage=Jsoup.connect(inner.select("a").attr("abs:href")).timeout(0).get();
  178.                                 Elements content=detailpage.select("div#zoom p");
  179.                                 for(Element el:content.select("img"))
  180.                                 {
  181.                                         final String url=el.attr("abs:src");
  182.                                         final String dst=el.attr("src");
  183.                                        
  184.                                         while(threadnum > 10)
  185.                                         {
  186.                                                 Thread.sleep(1000);
  187.                                         }
  188.                                        
  189.                                         new Thread()
  190.                                         {
  191.                                                 @Override
  192.                                                 public void run()
  193.                                                 {
  194.                                                         threadnum++;
  195.                                                         try
  196.                                                         {
  197.                                                                 downloadImage(url,dst,false);
  198.                                                         }
  199.                                                         catch (Exception e)
  200.                                                         {
  201.                                                                 // TODO Auto-generated catch block
  202.                                                                 e.printStackTrace();
  203.                                                         }
  204.                                                         finally
  205.                                                         {
  206.                                                                 threadnum--;
  207.                                                         }
  208.                                                 }
  209.                                         }.start();
  210.                                 }
  211.                                 
  212.                                 inbw.write(c("\t\t"+content.html().replace("/picture","picture")+"\n"));        
  213.                         }
  214.                         
  215.                         inbw.write(c("\t</div>\n</body>\n</html>"));
  216.                         inbw.close();
  217.                         inosw.close();
  218.                         infos.close();
  219.                 }
  220.                 bw.write(c("</keshis>\n"));
  221.                
  222.                 bw.close();
  223.                 osw.close();
  224.                 fos.close();
  225.         }
  226.         
  227.         public void downloadImage(String url,String dir,boolean change) throws Exception//下载图片并处理成合适大小
  228.         {
  229.                 String origindir=new String(dir);
  230.                 File file=null;
  231.                 StringBuilder curpath=new StringBuilder();
  232.                 if(dir.charAt(0) == '/')
  233.                         dir=dir.substring(1);
  234.                 while(dir.indexOf('/') != -1)
  235.                 {
  236.                         int index=dir.indexOf('/');
  237.                         curpath.append(dir.substring(0,index));
  238.                         file=new File(curpath.toString());
  239.                         if(!file.exists())
  240.                         {
  241.                                 file.mkdir();
  242.                         }
  243.                         curpath.append('/');
  244.                         dir=dir.substring(index+1);
  245.                 }
  246.                

  247.             int byteread=0;
  248.             int bytesum=0;
  249.             URL weburl=new URL(url);
  250.             URLConnection con=weburl.openConnection();
  251.             InputStream instream=con.getInputStream();
  252.             if(new File(curpath.toString()+dir).exists())
  253.                     return;
  254.             FileOutputStream fs=new FileOutputStream(curpath.toString()+dir);
  255.             FileOutputStream sfs=null;
  256.             if(change)
  257.                     sfs=new FileOutputStream(curpath.toString()+"small_"+dir);
  258.             byte[] buffer=new byte[65536];
  259.             while((byteread=instream.read(buffer)) != -1)
  260.             {
  261.                      bytesum+=byteread;
  262.                      fs.write(buffer,0,byteread);
  263.                      if(change)
  264.                              sfs.write(buffer,0,byteread);
  265.                      System.out.println("\t\t当前下载文件:"+url+"\t当前大小:"+bytesum);
  266.             }
  267.             if(change)
  268.                     sfs.close();
  269.             fs.close();
  270.             instream.close();
  271.             
  272.             if(change)
  273.             {
  274.                 //处理图片
  275.                     ImageUtil.resize(curpath.toString()+dir,curpath.toString()+dir,160,200);
  276.                           ImageUtil.resize(curpath.toString()+"small_"+dir,curpath.toString()+"small_"+dir,80,100);
  277.             }
  278.         }
  279.         
  280.         private class MyThread extends Thread
  281.         {
  282.                 private String downloadurl;
  283.                 private String picurl;
  284.                 private BufferedWriter bwp;
  285.                 private String doctorname;
  286.                
  287.                 public MyThread(Elements info,String picurl,BufferedWriter bwp,int i,Elements eles)
  288.                 {
  289.                         downloadurl=info.get(0).select("img").attr("abs:src");
  290.                         this.picurl=picurl;
  291.                         this.bwp=bwp;
  292.                         doctorname=eles.get(i).text();
  293.                 }
  294.                
  295.                 @Override
  296.                 public void run()
  297.                 {
  298.                         threadnum++;
  299.                         try
  300.                         {
  301.                                 downloadImage(downloadurl,picurl,true);
  302.                         }
  303.                         catch(Exception e)
  304.                         {
  305.                                 try
  306.                                 {
  307.                                         bwp.write("无头像:"+doctorname+"\n");
  308.                                 }
  309.                                 catch (IOException e1)
  310.                                 {
  311.                                         // TODO Auto-generated catch block
  312.                                         e1.printStackTrace();
  313.                                 }
  314.                         }
  315.                         finally
  316.                         {
  317.                                 threadnum--;
  318.                         }
  319.                 }
  320.         }
  321.         
  322.         public void processYisheng(Elements eles) throws Exception
  323.         {
  324.                 FileOutputStream fos=new FileOutputStream("名医大全.xml");
  325.                 OutputStreamWriter osw=new OutputStreamWriter(fos,"UTF-8");
  326.                 BufferedWriter bw=new BufferedWriter(osw);
  327.                 bw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  328.                 bw.write(c("<doctors>\n"));
  329.                 String fatherkeshiname="";
  330.                
  331.                 FileOutputStream fosp=new FileOutputStream("其他信息.xml");
  332.                 OutputStreamWriter oswp=new OutputStreamWriter(fosp);
  333.                 BufferedWriter bwp=new BufferedWriter(oswp);        
  334.                
  335.                 for(int i=0;i<eles.size();i++)
  336.                 {
  337.                         System.out.println(eles.get(i).attr("abs:href"));
  338.                         Document curdoc=Jsoup.connect(eles.get(i).attr("abs:href")).timeout(0).get();
  339.                         Elements temp1=curdoc.select("a[style=color:#0053a3;]");
  340.                         if(temp1.size() < 2)//竟然使用了个人主页!!!
  341.                         {
  342.                                 bwp.write("个人主页:"+eles.get(i).text()+"\n");
  343.                                 continue;
  344.                         }

  345.                         String curfather=temp1.get(temp1.size()-2).text();
  346.                         System.out.println("father:"+curfather);
  347.                         Elements info=curdoc.select("td[style=padding:6px 0px;] table tbody tr td table tbody tr").get(0).children();
  348.                         String picurl=info.get(0).select("img").attr("src");
  349.                         int index=picurl.lastIndexOf('/');
  350.                         String spicurl=picurl.substring(0,index+1)+"small_"+picurl.substring(index+1);
  351.                         
  352.                         if(i == 0)
  353.                         {
  354.                                 bw.write(c("<"+curfather+">\n"));
  355.                                 fatherkeshiname=curfather;
  356.                         }
  357.                         else if(!fatherkeshiname.equals(curfather))
  358.                         {
  359.                                 bw.write(c("<"+fatherkeshiname+">\n"));
  360.                                 fatherkeshiname=curfather;
  361.                                 bw.write(c("<"+fatherkeshiname+">\n"));
  362.                         }
  363.                         
  364.                         bw.write(c("\t<doctor>\n"));
  365.                         bw.write(c("\t\t<name>"+eles.get(i).text()+"</name>\n"));
  366.                         System.out.println(eles.get(i).text());
  367.                         bw.write(c("\t\t<id></id>\n"));
  368.                         Elements inner=info.get(2).children();
  369.                         bw.write(c("\t\t<summary>"+inner.get(2).text()+getProperText(inner.get(4).text())+"</summary>\n"));
  370.                         String doctorname=eles.get(i).text();
  371.                         bw.write(c("\t\t<detailurl>"+doctorname+".htm</detailurl>\n"));
  372.                         
  373.                         while(threadnum > 2)
  374.                         {
  375.                                 Thread.sleep(1000);
  376.                         }
  377.                         new MyThread(info,picurl,bwp,i,eles).start();
  378.                         
  379.                         bw.write(c("\t\t<smallpicurl>"+spicurl+"</smallpicurl>\n"));
  380.                         bw.write(c("\t\t<usefulinfourl>"+doctorname+".xml</usefulinfourl>\n"));//排班、评价、,,,
  381.                         bw.write(c("\t</doctor>\n"));
  382.                         
  383.                         if(i == eles.size()-1)
  384.                         {
  385.                                 bw.write(c("</"+curfather+">\n"));
  386.                         }
  387.                         
  388.                         FileOutputStream infos=new FileOutputStream(doctorname+".htm");
  389.                         OutputStreamWriter inosw=new OutputStreamWriter(infos,"UTF-8");
  390.                         BufferedWriter inbw=new BufferedWriter(inosw);
  391.                         inbw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  392.                         inbw.write(c("<!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">\n"));
  393.                         inbw.write(c("<html xmlns="http://www.w3.org/1999/xhtml">\n"));
  394.                         inbw.write(c("<head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>"+doctorname+"</title></head>\n"));
  395.                         inbw.write(c("<body>\n\t<div>\n"));
  396.                         
  397.                         for(Element el:info.select("img"))
  398.                         {
  399.                                 final String url=el.attr("abs:src");
  400.                                 final String dst=el.attr("src");
  401.                                 
  402.                                 while(threadnum > 10)
  403.                                 {
  404.                                         Thread.sleep(1000);
  405.                                 }
  406.                                 
  407.                                 new Thread()
  408.                                 {
  409.                                         @Override
  410.                                         public void run()
  411.                                         {
  412.                                                 threadnum++;
  413.                                                 try
  414.                                                 {
  415.                                                         downloadImage(url,dst,false);
  416.                                                 }
  417.                                                 catch (Exception e)
  418.                                                 {
  419.                                                         // TODO Auto-generated catch block
  420.                                                         e.printStackTrace();
  421.                                                 }
  422.                                                 finally
  423.                                                 {
  424.                                                         threadnum--;
  425.                                                 }
  426.                                         }
  427.                                 }.start();
  428.                         }
  429.                         
  430.                         inbw.write(c("\t\t"+info.html().replace("/picture","picture")+"\n"));
  431.                         inbw.write(c("\t</div>\n</body>\n</html>"));
  432.                         inbw.close();
  433.                         inosw.close();
  434.                         infos.close();
  435.                 }
  436.                
  437.                 bw.close();
  438.                 osw.close();
  439.                 fos.close();
  440.                
  441.                 bwp.close();
  442.                 oswp.close();
  443.                 fosp.close();
  444.         }
  445.         
  446.         private String getProperText(String src)
  447.         {
  448.                 if(src.length() > 128)
  449.                 {
  450.                         StringBuilder sb=new StringBuilder(src.substring(0, 128));
  451.                         for(int i=128;i<src.length();i++)
  452.                         {
  453.                                 char ch=src.charAt(i);
  454.                                 sb.append(ch);
  455.                                 if(ch == ',' || ch == '。' || ch == '、')
  456.                                 {
  457.                                         break;
  458.                                 }
  459.                         }
  460.                         sb.setCharAt(sb.length()-1,'。');
  461.                         return sb.toString();
  462.                 }
  463.                 else
  464.                         return src;
  465.         }
  466.         
  467.         public static void main(String[] args) throws Exception
  468.         {        
  469.                 new jsph();
  470.         }
  471. }


复制代码




ImageUtil.java 处理图片类,由于网上代码无法直接使用,因此做了微调

  1. package jsph;

  2. import java.awt.Color;
  3. import java.awt.Graphics2D;
  4. import java.awt.Image;
  5. import java.awt.Rectangle;
  6. import java.awt.image.BufferedImage;
  7. import java.io.File;
  8. import java.io.FileInputStream;
  9. import java.io.FileOutputStream;
  10. import java.io.IOException;
  11. import java.net.URL;
  12. import java.util.Date;
  13. import java.util.Iterator;

  14. import javax.imageio.ImageIO;
  15. import javax.imageio.ImageReadParam;
  16. import javax.imageio.ImageReader;
  17. import javax.imageio.stream.ImageInputStream;

  18.            
  19. /**
  20. * 图片压缩工具类 提供的方法中可以设定生成的 缩略图片的大小尺寸、压缩尺寸的比例、图片的质量等
  21. * <pre>
  22. *  调用示例:
  23. * resiz(srcImg, tarDir + "car_1_maxLength_11-220px-hui.jpg", 220, 0.7F);
  24. * </pre>
  25. *
  26. * @project haohui-b2b
  27. * @author cevencheng
  28. * @create 2012-3-22 下午8:29:01
  29. */
  30. public class ImageUtil
  31. {

  32.     /**
  33.      * * 图片文件读取
  34.      *
  35.      * @param srcImgPath
  36.      * @return
  37.      */
  38.     private static BufferedImage InputImage(String srcImgPath) throws RuntimeException
  39.     {

  40.         BufferedImage srcImage = null;
  41.         FileInputStream in = null;
  42.         try
  43.         {
  44.             // 构造BufferedImage对象
  45.             File file = new File(srcImgPath);
  46.             in = new FileInputStream(file);
  47.             byte[] b = new byte[5];
  48.             in.read(b);
  49.             srcImage = javax.imageio.ImageIO.read(file);
  50.         }
  51.         catch (IOException e)
  52.         {
  53.             e.printStackTrace();
  54.             throw new RuntimeException("读取图片文件出错!", e);
  55.         }
  56.         finally
  57.         {
  58.             if (in != null)
  59.             {
  60.                 try
  61.                 {
  62.                     in.close();
  63.                 }
  64.                 catch (IOException e)
  65.                 {
  66.                     throw new RuntimeException("读取图片文件出错!", e);
  67.                 }
  68.             }
  69.         }
  70.         return srcImage;
  71.     }

  72.     /**
  73.      * * 将图片按照指定的图片尺寸、源图片质量压缩(默认质量为1)
  74.      *
  75.      * @param srcImgPath
  76.      *            :源图片路径
  77.      * @param outImgPath
  78.      *            :输出的压缩图片的路径
  79.      * @param new_w
  80.      *            :压缩后的图片宽
  81.      * @param new_h
  82.      *            :压缩后的图片高
  83.      */
  84.     public static void resize(String srcImgPath, String outImgPath, int new_w, int new_h)
  85.     {
  86.         // 得到图片
  87.         BufferedImage src = InputImage(srcImgPath);
  88.         int old_w = src.getWidth();
  89.         // 得到源图宽
  90.         int old_h = src.getHeight();
  91.         // 得到源图长
  92.         // 根据原图的大小生成空白画布
  93.         BufferedImage tempImg = new BufferedImage(old_w, old_h,
  94.                 BufferedImage.TYPE_INT_RGB);
  95.         // 在新的画布上生成原图的缩略图
  96.         Graphics2D g = tempImg.createGraphics();
  97.         g.setColor(Color.white);
  98.         g.fillRect(0, 0, old_w, old_h);
  99.         g.drawImage(src, 0, 0, old_w, old_h, Color.white, null);
  100.         g.dispose();
  101.         BufferedImage newImg = new BufferedImage(new_w, new_h,
  102.                 BufferedImage.TYPE_INT_RGB);
  103.         newImg.getGraphics().drawImage( tempImg.getScaledInstance(new_w, new_h, Image.SCALE_SMOOTH), 0, 0, null);
  104.         // 调用方法输出图片文件
  105.         outImage(outImgPath, newImg);
  106.     }

  107.     /**
  108.      * 将图片按照指定的尺寸比例、源图片质量压缩(默认质量为1)
  109.      *
  110.      * @param srcImgPath
  111.      *            :源图片路径
  112.      * @param outImgPath
  113.      *            :输出的压缩图片的路径
  114.      * @param ratio
  115.      *            :压缩后的图片尺寸比例
  116.      * @param per
  117.      *            :百分比
  118.      */
  119.     public static void resize(String srcImgPath, String outImgPath, float ratio)
  120.     {
  121.         resize(srcImgPath, outImgPath, ratio, 1F);
  122.     }

  123.     /**
  124.      * 将图片按照指定长或者宽的最大值来压缩图片(默认质量为1)
  125.      *
  126.      * @param srcImgPath
  127.      *            :源图片路径
  128.      * @param outImgPath
  129.      *            :输出的压缩图片的路径
  130.      * @param maxLength
  131.      *            :长或者宽的最大值
  132.      * @param per
  133.      *            :图片质量
  134.      */
  135.     public static void resize(String srcImgPath, String outImgPath, int maxLength)
  136.     {
  137.         resize(srcImgPath, outImgPath, maxLength, 1F);
  138.     }

  139.     /**
  140.      * * 将图片按照指定的尺寸比例、图片质量压缩
  141.      *
  142.      * @param srcImgPath
  143.      *            :源图片路径
  144.      * @param outImgPath
  145.      *            :输出的压缩图片的路径
  146.      * @param ratio
  147.      *            :压缩后的图片尺寸比例
  148.      * @param per
  149.      *            :百分比
  150.      * @author cevencheng
  151.      */
  152.     public static void resize(String srcImgPath, String outImgPath,
  153.             float ratio, float per) {
  154.         // 得到图片
  155.         BufferedImage src = InputImage(srcImgPath);
  156.         int old_w = src.getWidth();
  157.         // 得到源图宽
  158.         int old_h = src.getHeight();
  159.         // 得到源图长
  160.         int new_w = 0;
  161.         // 新图的宽
  162.         int new_h = 0;
  163.         // 新图的长
  164.         BufferedImage tempImg = new BufferedImage(old_w, old_h,  BufferedImage.TYPE_INT_RGB);
  165.         Graphics2D g = tempImg.createGraphics();
  166.         g.setColor(Color.white);
  167.         // 从原图上取颜色绘制新图g.fillRect(0, 0, old_w, old_h);
  168.         g.drawImage(src, 0, 0, old_w, old_h, Color.white, null);
  169.         g.dispose();
  170.         // 根据图片尺寸压缩比得到新图的尺寸new_w = (int) Math.round(old_w * ratio);
  171.         new_h = (int) Math.round(old_h * ratio);
  172.         BufferedImage newImg = new BufferedImage(new_w, new_h, BufferedImage.TYPE_INT_RGB);
  173.         newImg.getGraphics().drawImage( tempImg.getScaledInstance(new_w, new_h, Image.SCALE_SMOOTH), 0,  0, null);
  174.         // 调用方法输出图片文件OutImage(outImgPath, newImg, per);
  175.     }

  176.     /**
  177.      * <b>
  178.      * 指定长或者宽的最大值来压缩图片
  179.      *  推荐使用此方法
  180.      * </b>
  181.      * @param srcImgPath
  182.      *            :源图片路径
  183.      * @param outImgPath
  184.      *            :输出的压缩图片的路径
  185.      * @param maxLength
  186.      *            :长或者宽的最大值
  187.      * @param per
  188.      *            :图片质量
  189.      * @author cevencheng
  190.      */
  191.     public static void resize(String srcImgPath, String outImgPath,  int maxLength, float per)
  192.     {
  193.         // 得到图片
  194.         BufferedImage src = InputImage(srcImgPath);
  195.         int old_w = src.getWidth();
  196.         // 得到源图宽
  197.         int old_h = src.getHeight();
  198.         // 得到源图长
  199.         int new_w = 0;
  200.         // 新图的宽
  201.         int new_h = 0;
  202.         // 新图的长
  203.         BufferedImage tempImg = new BufferedImage(old_w, old_h,  BufferedImage.TYPE_INT_RGB);
  204.         Graphics2D g = tempImg.createGraphics();
  205.         g.setColor(Color.white);
  206.         // 从原图上取颜色绘制新图
  207.         g.fillRect(0, 0, old_w, old_h);
  208.         g.drawImage(src, 0, 0, old_w, old_h, Color.white, null);
  209.         g.dispose();
  210.         // 根据图片尺寸压缩比得到新图的尺寸
  211.         if (old_w > old_h)
  212.         {
  213.             // 图片要缩放的比例
  214.             new_w = maxLength;
  215.             new_h = (int) Math.round(old_h * ((float) maxLength / old_w));
  216.         }
  217.         else
  218.         {
  219.             new_w = (int) Math.round(old_w * ((float) maxLength / old_h));
  220.             new_h = maxLength;
  221.         }
  222.         BufferedImage newImg = new BufferedImage(new_w, new_h, BufferedImage.TYPE_INT_RGB);
  223.         newImg.getGraphics().drawImage(  tempImg.getScaledInstance(new_w, new_h, Image.SCALE_SMOOTH), 0, 0, null);
  224.         // 调用方法输出图片文件
  225.         outImage(outImgPath, newImg);
  226.     }

  227.     /**
  228.      * 将图片压缩成指定宽度, 高度等比例缩放
  229.      *
  230.      * @param srcImgPath
  231.      * @param outImgPath
  232.      * @param width
  233.      * @param per
  234.      */
  235.     public static void resizeFixedWidth(String srcImgPath, String outImgPath, int width, float per)
  236.     {
  237.         // 得到图片
  238.         BufferedImage src = InputImage(srcImgPath);
  239.         int old_w = src.getWidth();
  240.         // 得到源图宽
  241.         int old_h = src.getHeight();
  242.         // 得到源图长
  243.         int new_w = 0;
  244.         // 新图的宽
  245.         int new_h = 0;
  246.         // 新图的长
  247.         BufferedImage tempImg = new BufferedImage(old_w, old_h, BufferedImage.TYPE_INT_RGB);
  248.         Graphics2D g = tempImg.createGraphics();
  249.         g.setColor(Color.white);
  250.         // 从原图上取颜色绘制新图
  251.         g.fillRect(0, 0, old_w, old_h);
  252.         g.drawImage(src, 0, 0, old_w, old_h, Color.white, null);
  253.         g.dispose();
  254.         // 根据图片尺寸压缩比得到新图的尺寸
  255.         if (old_w > old_h)
  256.         {
  257.             // 图片要缩放的比例
  258.             new_w = width;
  259.             new_h = (int) Math.round(old_h * ((float) width / old_w));
  260.         }
  261.         else
  262.         {
  263.             new_w = (int) Math.round(old_w * ((float) width / old_h));
  264.             new_h = width;
  265.         }
  266.         BufferedImage newImg = new BufferedImage(new_w, new_h, BufferedImage.TYPE_INT_RGB);
  267.         newImg.getGraphics().drawImage(  tempImg.getScaledInstance(new_w, new_h, Image.SCALE_SMOOTH), 0,  0, null);
  268.         // 调用方法输出图片文件
  269.         outImage(outImgPath, newImg);
  270.     }

  271.     /**
  272.      * * 将图片文件输出到指定的路径,并可设定压缩质量
  273.      *
  274.      * @param outImgPath
  275.      * @param newImg
  276.      * @param per
  277.      * @author cevencheng
  278.      */
  279.     private static void outImage(String outImgPath, BufferedImage newImg)
  280.     {
  281.         // 判断输出的文件夹路径是否存在,不存在则创建
  282.         File file = new File(outImgPath);
  283.         if (!file.exists())
  284.         {
  285.             file.mkdirs();
  286.         }

  287.         try
  288.         {
  289.                 String formatName=outImgPath.substring(outImgPath.lastIndexOf('.')+1);
  290.                 ImageIO.write(newImg, formatName, new File(outImgPath));
  291.         }
  292.         catch (Exception e)
  293.         {
  294.             throw new RuntimeException(e);
  295.         }
  296.     }

  297.     /**
  298.      * 图片剪切工具方法
  299.      *
  300.      * @param srcfile 源图片
  301.      * @param outfile 剪切之后的图片
  302.      * @param x 剪切顶点 X 坐标
  303.      * @param y 剪切顶点 Y 坐标
  304.      * @param width 剪切区域宽度
  305.      * @param height 剪切区域高度
  306.      *
  307.      * @throws IOException
  308.      * @author cevencheng
  309.      */
  310.     public static void cut(File srcfile, File outfile, int x, int y, int width, int height) throws IOException
  311.     {
  312.         FileInputStream is = null;
  313.         ImageInputStream iis = null;
  314.         try
  315.         {
  316.             // 读取图片文件
  317.             is = new FileInputStream(srcfile);

  318.             /*
  319.              * 返回包含所有当前已注册 ImageReader 的 Iterator,这些 ImageReader 声称能够解码指定格式。
  320.              * 参数:formatName - 包含非正式格式名称 .(例如 "jpeg" 或 "tiff")等 。
  321.              */
  322.             Iterator<ImageReader> it = ImageIO.getImageReadersByFormatName("jpg");
  323.             ImageReader reader = it.next();
  324.             // 获取图片流
  325.             iis = ImageIO.createImageInputStream(is);

  326.             /*
  327.              * <p>iis:读取源.true:只向前搜索 </p>.将它标记为 ‘只向前搜索’。
  328.              * 此设置意味着包含在输入源中的图像将只按顺序读取,可能允许 reader 避免缓存包含与以前已经读取的图像关联的数据的那些输入部分。
  329.              */
  330.             reader.setInput(iis, true);

  331.             /*
  332.              * <p>描述如何对流进行解码的类<p>.用于指定如何在输入时从 Java Image I/O
  333.              * 框架的上下文中的流转换一幅图像或一组图像。用于特定图像格式的插件 将从其 ImageReader 实现的
  334.              * getDefaultReadParam 方法中返回 ImageReadParam 的实例。
  335.              */
  336.             ImageReadParam param = reader.getDefaultReadParam();

  337.             /*
  338.              * 图片裁剪区域。Rectangle 指定了坐标空间中的一个区域,通过 Rectangle 对象
  339.              * 的左上顶点的坐标(x,y)、宽度和高度可以定义这个区域。
  340.              */
  341.             Rectangle rect = new Rectangle(x, y, width, height);

  342.             // 提供一个 BufferedImage,将其用作解码像素数据的目标。
  343.             param.setSourceRegion(rect);

  344.             /*
  345.              * 使用所提供的 ImageReadParam 读取通过索引 imageIndex 指定的对象,并将 它作为一个完整的
  346.              * BufferedImage 返回。
  347.              */
  348.             BufferedImage bi = reader.read(0, param);

  349.             // 保存新图片
  350.             ImageIO.write(bi, "jpg", outfile);
  351.         }
  352.         finally
  353.         {
  354.             if (is != null)
  355.             {
  356.                 is.close();
  357.             }
  358.             if (iis != null)
  359.             {
  360.                 iis.close();
  361.             }
  362.         }
  363.     }

  364.     public static void main(String args[]) throws Exception
  365.     {
  366.         String srcImg = "j:/branch.jpg";
  367.         resize(srcImg, srcImg, 200,200);
  368.         resize(srcImg, "111222.jpg", 200,200);
  369.     }
  370. }

复制代码



得到如下文件:
2014/04/06  13:44             2,000 HLA实验室.htm
2014/04/06  13:43             2,849 ICU.htm
2014/04/06  13:53    <DIR>          picture
2014/04/06  13:57             1,601 丁丽华.htm
2014/04/06  13:57             1,306 丁卫.htm
2014/04/06  13:57             1,098 丁强.htm
2014/04/06  13:57             1,604 丁新生.htm
2014/04/06  13:57             1,073 丁正年.htm
2014/04/06  13:58             1,444 丁炜.htm
2014/04/06  13:58             2,327 万琪.htm
2014/04/06  13:58             1,301 严友德.htm
2014/04/06  13:44             3,938 中医科.htm
2014/04/06  13:44               364 临床心理科.htm
2014/04/06  13:58             1,189 乔宗海.htm
2014/04/06  13:58             1,167 乔明哲.htm
2014/04/06  13:58             1,294 于 焱.htm
2014/04/06  13:58             1,594 于莲珍.htm
2014/04/06  13:44             2,855 产科.htm
2014/04/06  13:58             2,022 仇红霞.htm
2014/04/06  13:58             2,992 介入放射.htm
2014/04/06  13:58             1,032 付完珍.htm
2014/04/06  13:58             1,779 仲远明.htm
2014/04/06  13:58             2,059 何戎华.htm
2014/04/06  13:58             1,331 何畏.htm
2014/04/06  13:58             1,152 侯祚琼.htm
2014/04/06  13:58             1,296 俞同福.htm
2014/04/06  13:58             2,186 俞婉珍.htm
2014/04/06  13:58             1,525 俞明.htm
2014/04/06  13:58             1,629 俞香宝.htm
2014/04/06  13:58             1,234 倪金良.htm
2014/04/06  13:58             1,442 傅凤霞.htm
2014/04/06  13:58             1,430 傅士龙.htm
2014/04/06  13:58             1,825 傅赞.htm
2014/04/06  13:58             1,909 傅震.htm
2014/04/06  13:58             1,373 储旭华.htm
2014/04/06  13:58             1,084 储秋萍.htm
2014/04/06  13:44             6,421 儿科.htm
2014/04/06  13:44               899 儿童保健.htm
2014/04/06  13:48               513 其他信息.xml
2014/04/06  13:43             2,912 内分泌科.htm



下面这种全是自动生成:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>HLA实验室</title></head>
  5. <body>
  6.         <div>
  7.                 <span style="font-size: 20px">本</span>室是集医教研为一体的高新技术实验室,是中华骨髓库专家委员会委员单位,承担中华骨髓库江苏省分库的造血干细胞捐献志愿者HLA基因分型、临床造血干细胞移植和器官移植HLA组织配型及临床风险预测和相关医疗教学科研工作。该实验室2002年12月通过国家红十字总会组织的专家鉴定和认证,成为中华骨髓库定点组织配型实验室,并接受中华骨髓库常规及不定时、即时质控,且多年保持零错误率。
  8.     十年来,本室已对近50,000名造血干细胞捐献志愿者进行了HLA分型,建立了HLA分型档案和与中华骨髓库双向联动的功能性资料库,为国内外白血病患者寻找HLA完全匹配的非血缘关系的造血干细胞供者,其中已有142例在我院实施了造血干细胞采集。已从汉族人群中发现4个新等位基因,均获得WHO认证。
  9.     此外,本室已为院内外、省内外的临床3000多例亲缘关系、非亲缘关系供患者进行了HLA低分辨和高分辨配型。近年来,本实验室立足于规范化精细建设原则,在转换医学和医学科研上开拓特色,已进行疾病与HLA基因发病之间的研究工作,许多科研成果并已应用于临床。同时,该实验室还运用遗传流行病学和遗传免疫学手段,探索性进行地理遗传学比对和分析工作,为更多、更有效的寻找、确立移植供者提供依据,这一切均确立了本室在国内HLA科教研中的特色和地位。
  10.    
  11.         </div>
  12. </body>
  13. </html>

复制代码



  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">
  3. <html xmlns="http://www.w3.org/1999/xhtml">
  4. <head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>包丽华</title></head>
  5. <body>
  6.         <div>
  7.                 <table border="0" cellspacing="3" cellpadding="0" style="border:#e1e1e1 1px solid">
  8. <tbody>
  9.   <tr>
  10.    <td><img src="picture/0/1202221805195706215.JPG" width="89" height="118" border="0" />
  11.     <!--<IMG src='picture/0/ystp.gif' width=89 height=118 border=0>--></td>
  12.   </tr>
  13. </tbody>
  14. </table>

  15. <a href="/art/2010/3/10/art_1379_464.html" style=" color:#0163ae; font-size: 14px; text-decoration:none; font-weight: bold;">包丽华</a><br /><a style="color:#393c3c; font-size: 12px; text-decoration:none;">主任医师 副教授</a><br /><a style="color:#393c3c; font-size: 12px; text-decoration:none;">主任医师,副教授,硕士生导师,核医学科负责人,江苏省人民医院影像学部副主任,南京市医学会骨质疏松骨矿盐学会副主任委员,江苏省医学会骨质疏松学会委员。1985年毕业于南京医科大学医学系,从事临床医疗、教学及科研26年,擅长骨代谢疾病、骨质疏松及骨关节炎等疾病的诊断、预防和治疗。在SCI及核心期刊发表相关论著数十篇,参编专著多部,并多次获省、市科研奖项,主持或参与国家、省、市及院级骨质疏松课题多项,主持并参与十余项骨质疏松临床药物试验。专家门诊时间:每周二上午、周四上午、周五上午。</a>
  16.         </div>
  17. </body>
  18. </html>


  19. [code]
  20. <?xml version="1.0" encoding="utf-8"?>
  21. <doctors>
  22. <心血管内科>
  23.         <doctor>
  24.                 <name>孔祥清</name>
  25.                 <id></id>
  26.                 <summary>教授,主任医师,医学博士,博士生导师现任南京医科大学第一临床医学院院长、第一附属医院心内科主任。同时兼任FSCAI、中国生物医学工程学会介入医学工程分会副主任委员、中华医学会心血管病分会青年委员、中华医学会心血管病分会结构心脏病学组成员、中国医师协会结构心脏病学组副组长、中华医学会江苏心血管病分会副主任委员。</summary>
  27.                 <detailurl>孔祥清.htm</detailurl>
  28.                 <smallpicurl>picture/0/small_1202212326363771202.JPG</smallpicurl>
  29.                 <usefulinfourl>孔祥清.xml</usefulinfourl>
  30.         </doctor>
  31.         <doctor>
  32.                 <name>曹克将</name>
  33.                 <id></id>
  34.                 <summary>主任医师、教授、博士生导师南京医科大学(心血管病)国家重点学科带头人,现任中华医学会心电生理与起搏分会副主任委员、江苏省医学会心血管病专科分会主任委员、江苏省心肺疾病研究所所长、江苏省心血管病临床医学中心主任。 学科在2007年成为国家重点学科,2010年带领学科获卫生部心律失常、冠心病与先心病介入培训基地。</summary>
  35.                 <detailurl>曹克将.htm</detailurl>
  36.                 <smallpicurl>picture/0/small_s1203151656599155853.jpg</smallpicurl>
  37.                 <usefulinfourl>曹克将.xml</usefulinfourl>
  38.         </doctor>
  39.         <doctor>
  40.                 <name>黄峻</name>
  41.                 <id></id>
  42.                 <summary>主任医师享受国务院特殊津贴,主任医师、教授。擅长高血压、冠心病、心律失常及各类疑难危重心脏疾病的诊治。</summary>
  43.                 <detailurl>黄峻.htm</detailurl>
  44.                 <smallpicurl>picture/0/small_1202212325460412557.JPG</smallpicurl>
  45.                 <usefulinfourl>黄峻.xml</usefulinfourl>
  46.         </doctor>
  47.         <doctor>
  48.                 <name>黄元铸</name>
  49.                 <id></id>
  50.                 <summary>主任医师、教授,博导,院终身教授。擅长心脏病尤其冠心病、心律失常与疑难心脏病诊治。每周四上午专家门诊。</summary>
  51.                 <detailurl>黄元铸.htm</detailurl>
  52.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  53.                 <usefulinfourl>黄元铸.xml</usefulinfourl>
  54.         </doctor>
  55.         <doctor>
  56.                 <name>马文珠</name>
  57.                 <id></id>
  58.                 <summary>主任医师、教授,院终身教授。擅长心脏病尤其冠心病、心肌病的诊治。每周三上午专家门诊。</summary>
  59.                 <detailurl>马文珠.htm</detailurl>
  60.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  61.                 <usefulinfourl>马文珠.xml</usefulinfourl>
  62.         </doctor>
  63.         <doctor>
  64.                 <name>杨志健</name>
  65.                 <id></id>
  66.                 <summary>主任医师、教授主持多项国家级和省部级课题,主要研究方向是冠心病的早期诊断和生物学治疗,以第一作者或通讯作者发表SCI论文20余篇,正主持开展基因治疗二期临床工作;并主持搭建“冠心病专家远程医疗系统”平台,带动江苏省及邻近省份冠心病介入诊疗技术的快速发展。获江苏省优秀科技工作者等荣誉称号。</summary>
  67.                 <detailurl>杨志健.htm</detailurl>
  68.                 <smallpicurl>picture/0/small_1202212326539421951.JPG</smallpicurl>
  69.                 <usefulinfourl>杨志健.xml</usefulinfourl>
  70.         </doctor>
  71.         <doctor>
  72.                 <name>李新立</name>
  73.                 <id></id>
  74.                 <summary>主任医师、教授中华医学会心血管病分会心衰学组委员兼秘书、中国高血压联盟常委、中国医师协会高血压专业委员会常委、中国医师协会中西医结合医师分会心血管专家委员会常委。获得江苏省科学技术进步奖二等奖、江苏省突出贡献中青年专家。目前主持“十二五”国家科技支撑计划、国家自然科学基金。</summary>
  75.                 <detailurl>李新立.htm</detailurl>
  76.                 <smallpicurl>picture/0/small_1202271011315479273.JPG</smallpicurl>
  77.                 <usefulinfourl>李新立.xml</usefulinfourl>
  78.         </doctor>
  79.         <doctor>
  80.                 <name>单其俊</name>
  81.                 <id></id>
  82.                 <summary>医学博士,主任医师,教授。擅长各类心脏病的诊治,尤其是心律失常的介入诊治及心脏电生理与起搏治疗。每周四下午专家门诊。</summary>
  83.                 <detailurl>单其俊.htm</detailurl>
  84.                 <smallpicurl>picture/0/small_1202212327218808376.JPG</smallpicurl>
  85.                 <usefulinfourl>单其俊.xml</usefulinfourl>
  86.         </doctor>
  87.         <doctor>
  88.                 <name>许迪</name>
  89.                 <id></id>
  90.                 <summary>主任医师医学博士,主任医师、教授。擅长各类心脏病的诊治,尤其是心脏超声的临床应用、心脏电生理与起搏及先天性心脏病的诊治。每周一下午专家门诊。</summary>
  91.                 <detailurl>许迪.htm</detailurl>
  92.                 <smallpicurl>picture/0/small_1202270926526234565.JPG</smallpicurl>
  93.                 <usefulinfourl>许迪.xml</usefulinfourl>
  94.         </doctor>
  95.         <doctor>
  96.                 <name>邹建刚</name>
  97.                 <id></id>
  98.                 <summary>主任医师、教授现任江苏省人民医院、南京医科大学第一附属医院心脏科教授、主任医师,博士研究生导师,心律失常专业组副主任;中华医学会心电生理与起搏学会委员,中国CRT工作组副组长。 江苏省医学重点人才;省首批中青年科学技术带头人;省“六大人才高峰”高层次人才;2010年获中国CRT杰出成就奖。</summary>
  99.                 <detailurl>邹建刚.htm</detailurl>
  100.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  101.                 <usefulinfourl>邹建刚.xml</usefulinfourl>
  102.         </doctor>
  103.         <doctor>
  104.                 <name>陈明龙</name>
  105.                 <id></id>
  106.                 <summary>主任医师、教授主任医师,教授,博士生导师。现任南京医科大学一附院心内科副主任,中华医学会心电生理与起搏分会委员,中国心律学会委员,江苏省心血管病学会秘书。擅长心血管内科相关疾病尤其是心律失常的诊治。曾荣获江苏省科学技术进步奖二等奖1项、江苏省医学新技术引进奖一等奖3项、江苏省卫生厅新技术引进特等奖1项。</summary>
  107.                 <detailurl>陈明龙.htm</detailurl>
  108.                 <smallpicurl>picture/0/small_s1203221028183788908.JPG</smallpicurl>
  109.                 <usefulinfourl>陈明龙.xml</usefulinfourl>
  110.         </doctor>
  111.         <doctor>
  112.                 <name>朱铁兵</name>
  113.                 <id></id>
  114.                 <summary>主任医师医学博士,主任医师、教授。擅长各类心脏病的诊治,尤其擅长冠心病的介入治疗。每周三上午专家门诊。</summary>
  115.                 <detailurl>朱铁兵.htm</detailurl>
  116.                 <smallpicurl>picture/0/small_1202271021234004728.JPG</smallpicurl>
  117.                 <usefulinfourl>朱铁兵.xml</usefulinfourl>
  118.         </doctor>
  119.         <doctor>
  120.                 <name>张寄南</name>
  121.                 <id></id>
  122.                 <summary>主任医师主任医师、教授。享受国务院特殊津贴。擅长病毒性心肌炎、心肌病、高血压、心肌梗塞及心脏疑难疾病的诊治。 每周五上午专家门诊。</summary>
  123.                 <detailurl>张寄南.htm</detailurl>
  124.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  125.                 <usefulinfourl>张寄南.xml</usefulinfourl>
  126.         </doctor>
  127.         <doctor>
  128.                 <name>张馥敏</name>
  129.                 <id></id>
  130.                 <summary>主任医师主任医师、教授。擅长冠心病、心律失常及各类疑难危重心脏疾病及心衰的诊治。</summary>
  131.                 <detailurl>张馥敏.htm</detailurl>
  132.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  133.                 <usefulinfourl>张馥敏.xml</usefulinfourl>
  134.         </doctor>
  135.         <doctor>
  136.                 <name>钱卫冲</name>
  137.                 <id></id>
  138.                 <summary>主任医师主任医师,副教授。能诊断处理各种常见心血管病,擅长对高血压病、冠心病及心力衰竭的诊断、治疗及综合管理。</summary>
  139.                 <detailurl>钱卫冲.htm</detailurl>
  140.                 <smallpicurl>picture/0/small_1202271027314514069.JPG</smallpicurl>
  141.                 <usefulinfourl>钱卫冲.xml</usefulinfourl>
  142.         </doctor>
  143.         <doctor>
  144.                 <name>李殿富</name>
  145.                 <id></id>
  146.                 <summary>主任医师医学博士,主任医师,副教授。擅长各类心脏病的诊治,尤其擅长冠心病介入技术和无创技术(核素心肌显像),对冠心病和胸痛的规范化诊治有丰富经验。</summary>
  147.                 <detailurl>李殿富.htm</detailurl>
  148.                 <smallpicurl>picture/0/small_1202212329319829385.JPG</smallpicurl>
  149.                 <usefulinfourl>李殿富.xml</usefulinfourl>
  150.         </doctor>
  151.         <doctor>
  152.                 <name>周秀娟</name>
  153.                 <id></id>
  154.                 <summary>主任医师医学博士,主任医师,副教授,硕士生导师,长期从事临床一线工作,熟练掌握心脏科各种常见病的诊断和治疗,尤其是高血压、冠心病、心肌病、心律失常的临床诊治,擅长心脏起搏器植入术及术后程控随访,对遗传性心律失常,如致心律失常右室心肌病有较深入研究,主持国家自然科学基金。</summary>
  155.                 <detailurl>周秀娟.htm</detailurl>
  156.                 <smallpicurl>picture/0/small_1311151216574162069.jpg</smallpicurl>
  157.                 <usefulinfourl>周秀娟.xml</usefulinfourl>
  158.         </doctor>
  159.         <doctor>
  160.                 <name>王连生</name>
  161.                 <id></id>
  162.                 <summary>主任医师、教授南京医科大学第一附属医院(江苏省人民医院)内科心血管病主任医师、教授、高级专家,博士研究生导师和卫生部心血管疾病介入诊疗培训基地“冠心病介入”导师,医学博士,留美学者。长期从事冠心病、高血压、高脂血症和心力衰竭的临床诊疗工作,精通各种心血管常见病与疑难危重病人的诊疗。</summary>
  163.                 <detailurl>王连生.htm</detailurl>
  164.                 <smallpicurl>picture/0/small_1202271029068548435.JPG</smallpicurl>
  165.                 <usefulinfourl>王连生.xml</usefulinfourl>
  166.         </doctor>
  167.         <doctor>
  168.                 <name>李春坚</name>
  169.                 <id></id>
  170.                 <summary>主任医师、教授、博士生导师主任医师、教授、博士生导师 德国Heidelberg大学和加拿大McMaster大学访问学者;江苏省六大高峰人才;江苏省333高层次人才;江苏省医学重点人才(共建); International Journal of Cardiology (SCI IF 5.509)同行评审专家。</summary>
  171.                 <detailurl>李春坚.htm</detailurl>
  172.                 <smallpicurl>picture/0/small_1202271030294711124.JPG</smallpicurl>
  173.                 <usefulinfourl>李春坚.xml</usefulinfourl>
  174.         </doctor>
  175.         <doctor>
  176.                 <name>杨 荣</name>
  177.                 <id></id>
  178.                 <summary>主任医师、副教授主任医师、副教授。从事心脏病临床诊治工作,擅长先心病的临床诊治,尤其擅长先心病的介入诊治,中国先心病介入培训基地导师,在国内外医学期刊发表文章30余篇,获省、厅和院级医学奖8项。 每周四上午门诊。</summary>
  179.                 <detailurl>杨 荣.htm</detailurl>
  180.                 <smallpicurl>picture/0/small_1202212330028289166.JPG</smallpicurl>
  181.                 <usefulinfourl>杨 荣.xml</usefulinfourl>
  182.         </doctor>
  183.         <doctor>
  184.                 <name>卢新政</name>
  185.                 <id></id>
  186.                 <summary>副主任医师医学博士后,副主任医师,副教授。擅长各类心脏病的诊治,尤其是高血压病、心力衰竭、心肌病等的临床诊治。</summary>
  187.                 <detailurl>卢新政.htm</detailurl>
  188.                 <smallpicurl>picture/0/small_1202212330345274772.JPG</smallpicurl>
  189.                 <usefulinfourl>卢新政.xml</usefulinfourl>
  190.         </doctor>
  191.         <doctor>
  192.                 <name>王 晖</name>
  193.                 <id></id>
  194.                 <summary>副主任医师医学博士,副主任医师、副教授。熟练掌握各种危重心血管病的临床诊治,擅长冠心病介入诊治。</summary>
  195.                 <detailurl>王 晖.htm</detailurl>
  196.                 <smallpicurl>picture/0/small_ystp.gif</smallpicurl>
  197.                 <usefulinfourl>王 晖.xml</usefulinfourl>
  198.         </doctor>
  199.         <doctor>
  200.                 <name>杨 兵</name>
  201.                 <id></id>
  202.                 <summary>主任医师、教授医学博士,主任医师、教授。熟练掌握心内科常见病和多发病的诊治,主要从事心律失常的临床和基础研究,擅长于起搏治疗缓慢性心律失常和导管射频消融治疗各种快速性心律失常,特别在应用新型三维标测系统治疗各种复杂快速性心律失常,如心房颤动、房性心动过速、心房扑动、室性心动过速等方面有丰富的经验。</summary>
  203.                 <detailurl>杨 兵.htm</detailurl>
  204.                 <smallpicurl>picture/0/small_1202212332098006091.JPG</smallpicurl>
  205.                 <usefulinfourl>杨 兵.xml</usefulinfourl>
  206.         </doctor>

  207. ...........................
复制代码



重点专科.htm

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <keshis>
  3.         <keshi>
  4.                 <name>内科</name>
  5.                 <id></id>
  6.                 <isroot>true</isroot>
  7.         </keshi>
  8.         <keshi>
  9.                 <name>外科</name>
  10.                 <id></id>
  11.                 <isroot>true</isroot>
  12.         </keshi>
  13.         <keshi>
  14.                 <name>内科</name>
  15.                 <id></id>
  16.                 <isroot>true</isroot>
  17.         </keshi>
  18.         <keshi>
  19.                 <name>老年病学科</name>
  20.                 <id>13</id>
  21.                 <isroot>true</isroot>
  22.         </keshi>
  23.         <keshi>
  24.                 <name>康复医学科</name>
  25.                 <summary>江苏省人民医院康复医学科成立于1956年,55年来学科发展迅速,目前已成立了康复医学中心。现有康复门诊800平方米,病房76张床位、盛泽分院康复医学科22张床位,江苏省人民医院康复医学分院是国内三级甲等医院中临床规模最大、设备最齐全、技术实力最强的科室之一</summary>
  26.                 <detailurl>康复医学科.htm</detailurl>
  27.                 <id>37</id>
  28.                 <isroot>true</isroot>
  29.         </keshi>
  30.         <keshi>
  31.                 <name>妇产科</name>
  32.                 <id></id>
  33.                 <isroot>true</isroot>
  34.         </keshi>
  35.         <keshi>
  36.                 <name>儿科</name>
  37.                 <id>28</id>
  38.                 <isroot>true</isroot>
  39.         </keshi>
  40.         <keshi>
  41.                 <name>门急诊</name>
  42.                 <id></id>
  43.                 <isroot>true</isroot>
  44.         </keshi>
  45.         <keshi>
  46.                 <name>医技</name>
  47.                 <id></id>
  48.                 <isroot>true</isroot>
  49.         </keshi>
  50.         <内科>
  51.                 <keshi>
  52.                         <name>心血管内科</name>
  53.                         <id></id>
  54.                         <summary>????南京医科大学心血管内科创建于1952年,1981年和1986年分别被批准为硕士学位和博士学位授权点,1998年被授予临床医学博士后科研流动站。江苏省政府重点学科、江苏省心血管病临床医学中心,2007被评为国家重点学科。[详细内容]</summary>
  55.                         <detailurl>心血管内科.htm</detailurl>
  56.                 </keshi>
  57.                 <keshi>
  58.                         <name>呼吸内科</name>
  59.                         <id></id>
  60.                         <summary>????现为江苏省医学重点学科、江苏省临床重点专科、江苏省“呼吸内科专业医疗质量控制中心”、江苏省卫生厅“135工程”重点学科、“科教兴卫工程”重点学科、国家首批“临床药理研究基地”、卫生部“专科医师规范化培训基地”、卫生部首批“呼吸内镜诊疗技术培训基地”。</summary>
  61.                         <detailurl>呼吸内科.htm</detailurl>
  62.                 </keshi>
  63.                 <keshi>
  64.                         <name>内分泌科</name>
  65.                         <id></id>
  66.                         <summary>????1986年被国家教委批准为内分泌专业博士授予点,1996年被江苏省卫生厅批准为重点学科,1998年成为国家医学继续教育基地和国家药品临床验证机构。课题方面,近3年来承担重大课题3项、国际合作项目1项、国家自然科学基金14项,其他省部级课题17项,科技重大专项基金3项。</summary>
  67.                         <detailurl>内分泌科.htm</detailurl>
  68.                 </keshi>
  69.                 <keshi>
  70.                         <name>血液内科</name>
  71.                         <id></id>
  72.                         <summary>????南京医科大学第一附属医院(江苏省人民医院)血液科简介 南京医科大学第一附属医院(江苏省人民医院)血液科是国家临床重点专科建设单位、江苏省优势学科(临床医学)、江苏省重点学科(内科)、江苏省兴卫工程重点学科(共建)、江苏省临床重点专科、江苏省高校优秀科技创新团队。</summary>
  73.                         <detailurl>血液内科.htm</detailurl>
  74.                 </keshi>
  75.                 <keshi>
  76.                         <name>消化内科</name>
  77.                         <id></id>
  78.                         <summary>????江苏省人民医院消化科是江苏省“135”和“兴卫工程”医学重点学科,江苏省卫生厅重点临床专科。卫生部消化医师专科培训基地(示范点),卫生部消化内镜诊疗培训基地,卫生部内镜消毒灭菌培训基地. 自上世纪60 年代创建以来,学科建设蓬勃发展,规模逐步扩大。现有消化门诊(专科和专家门诊)。</summary>
  79.                         <detailurl>消化内科.htm</detailurl>
  80.                 </keshi>
  81.                 <keshi>
  82.                         <name>肾内科</name>
  83.                         <id></id>
  84.                         <summary>????本学科为我国最早建立肾脏病专科和血液透析中心的单位之一。现已成为拥有一个达全国一流、国际先进水平的血液净化中心,及相应规模病房的学术专科。是南京医科大学博士、硕士授予点,江苏省教委重点学科、江苏省重点专科,卫生部专科医师培训基地,国家临床药物试验机构。</summary>
  85.                         <detailurl>肾内科.htm</detailurl>
  86.                 </keshi>
  87.                 <keshi>
  88.                         <name>神经内科</name>
  89.                         <id></id>
  90.                         <summary>????南京医科大学附属第一医院神经内科现由二个病区(70张床)、门诊、急诊、神经电生理实验室和临床神经病学研究室(脑脊液细胞研究室)所构成。每年收容各类神经系统疑难危重病人1000人次,门诊诊治7万多人次,急诊抢救近1万人次。本学科在神经系统各类疾病的诊治方面有着丰富的临床经验。</summary>
  91.                         <detailurl>神经内科.htm</detailurl>
  92.                 </keshi>
  93.                 <keshi>
  94.                         <name>风湿免疫科</name>
  95.                         <id></id>
  96.                         <summary>????江苏省人民医院风湿科1992年成立,2009年获江苏省风湿病学临床重点专科,是南京医科大学临床风湿免疫硕士学位授予点,从属的大内科是内科学博士学位授予点及内科博士后流动站。目前有独立的专科实验室以及每日开诊的专家、专科门诊。本专科实验室及临床免疫实验室设备先进。</summary>
  97.                         <detailurl>风湿免疫科.htm</detailurl>
  98.                 </keshi>
  99.                 <keshi>
  100.                         <name>感染病科</name>
  101.                         <id></id>
  102.                         <summary>????在著名热带病学家许本谦教授和陈钟英、贾辅忠、王明秀、唐保元、黄祖瑚、李军等历届科主任的带领下,经过数十年的艰苦努力,在常见重大传染性疾病的诊断治疗、临床教学、科研工作、人才培养和学科建设等方面取得了显著成绩。今天的感染病科设施优良,宽敞明亮的门诊大厅。</summary>
  103.                         <detailurl>感染病科.htm</detailurl>
  104.                 </keshi>
  105.                 <keshi>
  106.                         <name>肿瘤科</name>
  107.                         <id></id>
  108.                         <summary>????江苏省人民医院肿瘤科为江苏省人民医院重点发展科室之一,科室研究室为江苏省135重点实验室之一。曾获江苏省“十一五”肿瘤重点学科,是江苏省“兴卫工程”高技术平台培育点之一,卫生部“高强度聚焦超声技术治疗肿瘤综合评价”培育点之一。科室自1999年底成立。</summary>
  109.                         <detailurl>肿瘤科.htm</detailurl>
  110.                 </keshi>
  111.                 <keshi>
  112.                         <name>皮肤科</name>
  113.                         <id></id>
  114.                         <summary>????江苏省人民医院皮肤科始建于1948年,历史悠久,技术精良, 是江苏省内综合医院中学术规模最大、综合实力最强的皮肤病专业诊疗机构,专业治疗各种皮肤病和性病。我科为国务院首批博士点授予点,目前为江苏省重点学科、博士后流动站,是国家卫生部皮肤性病学科药理基地。</summary>
  115.                         <detailurl>皮肤科.htm</detailurl>
  116.                 </keshi>
  117.                 <keshi>
  118.                         <name>普通内科(全科医学)</name>
  119.                         <id></id>
  120.                         <summary>????[详细内容]</summary>
  121.                         <detailurl>普通内科(全科医学).htm</detailurl>
  122.                 </keshi>
  123.                 <keshi>
  124.                         <name>河西综合内科(心血管)</name>
  125.                         <id></id>
  126.                         <summary>????[详细内容]</summary>
  127.                         <detailurl>河西综合内科(心血管).htm</detailurl>
  128.                 </keshi>
  129.         </内科>
  130.         <外科>
  131.                 <keshi>
  132.                         <name>麻醉手术科</name>
  133.                         <id></id>
  134.                         <summary>????江苏省人民医院(南京医科大学第一附属医院)麻醉科是江苏省重点临床专科,江苏省“135”医学重点共建学科。江苏省人民医院麻醉科专科特色鲜明,尤其是危、重、疑、难、杂病人的麻醉、器官移植病人的麻醉,在麻醉与内分泌、药物对支气管平滑肌张力的影响等方面在国内具有一定的影响。</summary>
  135.                         <detailurl>麻醉手术科.htm</detailurl>
  136.                 </keshi>
  137.                 <keshi>
  138.                         <name>ICU</name>
  139.                         <id></id>
  140.                         <summary>????监护病房筹建于1983年8月,于1984年9月28日正式接受病人,设床位6张,是国内最早成立的ICU之一。1985年2月,时任院长林桂芳兼任科主任,同年5月,奚云清任科副主任,并聘请王一镗教授和李德馨主任为顾问。1990年徐鑫荣任科主任。经过20年的发展。</summary>
  141.                         <detailurl>ICU.htm</detailurl>
  142.                 </keshi>
  143.                 <keshi>
  144.                         <name>骨科</name>
  145.                         <id></id>
  146.                         <summary>????南京医科大学第一附属医院(江苏省人民医院)骨科是江苏省“135”工程重点学科,博士、硕士学位授予点、博士后流动站,含3个病区105张床位;共有医护人员84名,其中医生37名,技师3名,护理人员44名;拥有教授、主任医师10人,副教授、副主任医师11人。</summary>
  147.                         <detailurl>骨科.htm</detailurl>
  148.                 </keshi>

  149. .....................
复制代码


QQ图片20140406142352.jpg


回复

使用道具 举报

 楼主| 发表于 2014-4-7 12:44:55 | 显示全部楼层
0xAA55 发表于 2014-4-7 00:07
跪求4字符的TAB啊

啥意思
修改后的jsph.java


  1. package jsph;

  2. import java.io.BufferedWriter;
  3. import java.io.File;
  4. import java.io.FileOutputStream;
  5. import java.io.IOException;
  6. import java.io.InputStream;
  7. import java.io.OutputStreamWriter;
  8. import java.io.UnsupportedEncodingException;
  9. import java.io.Writer;
  10. import java.net.URL;
  11. import java.net.URLConnection;

  12. import org.jsoup.Jsoup;
  13. import org.jsoup.nodes.Document;
  14. import org.jsoup.nodes.Element;
  15. import org.jsoup.nodes.Node;
  16. import org.jsoup.select.Elements;

  17. public class jsph
  18. {
  19.         private String keshijieshao="http://www.jsph.net/col/col25/index.html";
  20.         private String[] names={"内科","外科","老年医学科","康复医学科","妇产科","儿科","门急诊","医技"};
  21.         private String[] addrs=
  22.         {
  23.                 "http://www.jsph.net/col/col861/index.html",
  24.                 "http://www.jsph.net/col/col862/index.html",
  25.                 "http://www.jsph.net/col/col863/index.html",
  26.                 "http://www.jsph.net/col/col864/index.html",
  27.                 "http://www.jsph.net/col/col865/index.html",
  28.                 "http://www.jsph.net/col/col866/index.html",
  29.                 "http://www.jsph.net/col/col867/index.html",
  30.                 "http://www.jsph.net/col/col868/index.html",
  31.         };
  32.        
  33.         private String url="http://www.jsph.net/script/0/nav.js";
  34.         private int threadnum=0;
  35.        
  36.         public jsph()
  37.         {
  38.                 try
  39.                 {
  40.                         Document keshidoc=Jsoup.connect(keshijieshao).timeout(0).get();
  41.                         Elements toprocess=keshidoc.select("a[style=font-size:14px;]");
  42.                         toprocess.addAll(keshidoc.select("a[style=font-size:14px; width:100px]"));
  43. //                        processKeshi(toprocess);
  44.                         Elements doctorlist=new Elements();
  45.                        
  46.                         int i,j;
  47.                         for(i=0;i<names.length;i++)
  48.                         {
  49.                                 Document doc=Jsoup.connect(addrs[i]).timeout(0).get();
  50.                                 Elements eles=doc.select("td[width=752]").get(0).children();
  51.                                 for(j=11;j<eles.size();j+=2)
  52.                                 {
  53.                                         doctorlist.addAll(eles.get(j).select("a"));
  54.                                         if(j+1<eles.size() && eles.get(j+1).text().equals(""))
  55.                                                 j++;
  56.                                 }                               
  57.                         }
  58.                         for(Element ss:doctorlist)
  59.                                 System.out.println(ss.text());
  60.                         processYisheng(doctorlist);
  61.                 }
  62.                 catch (Exception e)
  63.                 {
  64.                         e.printStackTrace();
  65.                 }
  66.         }
  67.        
  68.         public String c(String src) throws Exception
  69.         {
  70. //                return src;
  71.                 return new String(src.getBytes(),"gb2312");
  72.         }
  73.        
  74.         public void processKeshi(Elements eles) throws Exception
  75.         {
  76.                 FileOutputStream fos=new FileOutputStream("重点专科.xml");
  77.                 OutputStreamWriter osw=new OutputStreamWriter(fos,"UTF-8");
  78.                 BufferedWriter bw=new BufferedWriter(osw);
  79.                 bw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  80.                 bw.write(c("<keshis>\n"));
  81.                 bw.write(c("\t<keshi>\n"));
  82.                 bw.write(c("\t\t<name>内科</name>\n"));
  83.                 bw.write(c("\t\t<id></id>\n"));
  84.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  85.                 bw.write(c("\t</keshi>\n"));
  86.                
  87.                 bw.write(c("\t<keshi>\n"));
  88.                 bw.write(c("\t\t<name>外科</name>\n"));
  89.                 bw.write(c("\t\t<id></id>\n"));
  90.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  91.                 bw.write(c("\t</keshi>\n"));       
  92.                
  93.                 bw.write(c("\t<keshi>\n"));
  94.                 bw.write(c("\t\t<name>老年病学科</name>\n"));
  95.                 bw.write(c("\t\t<id>13</id>\n"));
  96.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  97.                 bw.write(c("\t</keshi>\n"));
  98.                
  99.                 bw.write(c("\t<keshi>\n"));
  100.                 bw.write(c("\t\t<name>康复医学科</name>\n"));
  101.                 bw.write(c("\t\t<summary>江苏省人民医院康复医学科成立于1956年,55年来学科发展迅速,目前已成立了康复医学中心。"
  102.                                 + "现有康复门诊800平方米,病房76张床位、盛泽分院康复医学科22张床位,江苏省人民医院康复医学分院是国内三级甲等"
  103.                                 + "医院中临床规模最大、设备最齐全、技术实力最强的科室之一</summary>\n"));
  104.                 bw.write(c("\t\t<detailurl>康复医学科.htm</detailurl>\n"));
  105.                 bw.write(c("\t\t<id>37</id>\n"));
  106.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  107.                 bw.write(c("\t</keshi>\n"));
  108.                
  109.                 bw.write(c("\t<keshi>\n"));
  110.                 bw.write(c("\t\t<name>妇产科</name>\n"));
  111.                 bw.write(c("\t\t<id></id>\n"));
  112.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  113.                 bw.write(c("\t</keshi>\n"));
  114.        
  115.                 bw.write(c("\t<keshi>\n"));
  116.                 bw.write(c("\t\t<name>儿科</name>\n"));
  117.                 bw.write(c("\t\t<id>28</id>\n"));
  118.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  119.                 bw.write(c("\t</keshi>\n"));
  120.                
  121.                 bw.write(c("\t<keshi>\n"));
  122.                 bw.write(c("\t\t<name>门急诊</name>\n"));
  123.                 bw.write(c("\t\t<id></id>\n"));
  124.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  125.                 bw.write(c("\t</keshi>\n"));
  126.                
  127.                 bw.write(c("\t<keshi>\n"));
  128.                 bw.write(c("\t\t<name>医技</name>\n"));
  129.                 bw.write(c("\t\t<id></id>\n"));
  130.                 bw.write(c("\t\t<isroot>true</isroot>\n"));
  131.                 bw.write(c("\t</keshi>\n"));
  132.                
  133.                 String fatherkeshiname="";
  134.                 for(int i=0;i<eles.size();i++)
  135.                 {
  136.                         Document curdoc=Jsoup.connect(eles.get(i).attr("abs:href")).timeout(0).get();
  137.                         Elements temp1=curdoc.select("a[style=color:#0053a3;]");
  138.                         String curfather=temp1.get(temp1.size()-2).text();
  139.                         System.out.println("father:"+curfather);
  140.                         if(i == 0)
  141.                         {
  142.                                 bw.write(c("\t<"+curfather+">\n"));
  143.                                 fatherkeshiname=curfather;
  144.                         }
  145.                         else if(!fatherkeshiname.equals(curfather))
  146.                         {
  147.                                 bw.write(c("\t</"+fatherkeshiname+">\n"));
  148.                                 fatherkeshiname=curfather;
  149.                                 bw.write(c("\t<"+fatherkeshiname+">\n"));
  150.                         }
  151.                        
  152.                         bw.write(c("\t\t<keshi>\n"));
  153.                         bw.write(c("\t\t\t<name>"+eles.get(i).text()+"</name>\n"));
  154.                         System.out.println(eles.get(i).text());
  155.                         bw.write(c("\t\t\t<id></id>\n"));
  156.                         Elements inner=curdoc.select("td[style=padding:0px 10px 0px 10px;]\n");
  157.                         bw.write(c("\t\t\t<summary>"+getProperText(inner.text())+"</summary>\n"));
  158.                         String keshiname=eles.get(i).text();
  159.                         bw.write(c("\t\t\t<detailurl>"+keshiname+".htm</detailurl>\n"));
  160.                         bw.write(c("\t\t</keshi>\n"));
  161.                        
  162.                         if(i == eles.size()-1)
  163.                         {
  164.                                 bw.write(c("\t</"+curfather+">\n"));
  165.                         }
  166.                        
  167.                         FileOutputStream infos=new FileOutputStream(keshiname+".htm");
  168.                         OutputStreamWriter inosw=new OutputStreamWriter(infos,"UTF-8");
  169.                         BufferedWriter inbw=new BufferedWriter(inosw);
  170.                         inbw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  171.                         inbw.write(c("<!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">\n"));
  172.                         inbw.write(c("<html xmlns="http://www.w3.org/1999/xhtml">\n"));
  173.                         inbw.write(c("<head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>"+keshiname+"</title></head>\n"));
  174.                         inbw.write(c("<body>\n\t<div>\n"));
  175.                         if(inner.select("a").size() != 0)
  176.                         {
  177.                                 Document detailpage=Jsoup.connect(inner.select("a").attr("abs:href")).timeout(0).get();
  178.                                 Elements content=detailpage.select("div#zoom p");
  179.                                 for(Element el:content.select("img"))
  180.                                 {
  181.                                         final String url=el.attr("abs:src");
  182.                                         final String dst=el.attr("src");
  183.                                        
  184.                                         while(threadnum > 10)
  185.                                         {
  186.                                                 Thread.sleep(1000);
  187.                                         }
  188.                                        
  189.                                         new Thread()
  190.                                         {
  191.                                                 @Override
  192.                                                 public void run()
  193.                                                 {
  194.                                                         threadnum++;
  195.                                                         try
  196.                                                         {
  197.                                                                 downloadImage(url,dst,false);
  198.                                                         }
  199.                                                         catch (Exception e)
  200.                                                         {
  201.                                                                 // TODO Auto-generated catch block
  202.                                                                 e.printStackTrace();
  203.                                                         }
  204.                                                         finally
  205.                                                         {
  206.                                                                 threadnum--;
  207.                                                         }
  208.                                                 }
  209.                                         }.start();
  210.                                 }
  211.                                
  212.                                 inbw.write(c("\t\t"+content.html().replace("/picture","picture")+"\n"));       
  213.                         }
  214.                        
  215.                         inbw.write(c("\t</div>\n</body>\n</html>"));
  216.                         inbw.close();
  217.                         inosw.close();
  218.                         infos.close();
  219.                 }
  220.                 bw.write(c("</keshis>\n"));
  221.                
  222.                 bw.close();
  223.                 osw.close();
  224.                 fos.close();
  225.         }
  226.        
  227.         public void downloadImage(String url,String dir,boolean change) throws Exception//下载图片并处理成合适大小
  228.         {
  229.                 String origindir=new String(dir);
  230.                 File file=null;
  231.                 StringBuilder curpath=new StringBuilder();
  232.                 if(dir.charAt(0) == '/')
  233.                         dir=dir.substring(1);
  234.                 while(dir.indexOf('/') != -1)
  235.                 {
  236.                         int index=dir.indexOf('/');
  237.                         curpath.append(dir.substring(0,index));
  238.                         file=new File(curpath.toString());
  239.                         if(!file.exists())
  240.                         {
  241.                                 file.mkdir();
  242.                         }
  243.                         curpath.append('/');
  244.                         dir=dir.substring(index+1);
  245.                 }
  246.                

  247.             int byteread=0;
  248.             int bytesum=0;
  249.             URL weburl=new URL(url);
  250.             URLConnection con=weburl.openConnection();
  251.             InputStream instream=con.getInputStream();
  252.             if(new File(curpath.toString()+dir).exists())
  253.                     return;
  254.             FileOutputStream fs=new FileOutputStream(curpath.toString()+dir);
  255.             FileOutputStream sfs=null;
  256.             if(change)
  257.                     sfs=new FileOutputStream(curpath.toString()+"small_"+dir);
  258.             byte[] buffer=new byte[65536];
  259.             while((byteread=instream.read(buffer)) != -1)
  260.             {
  261.                      bytesum+=byteread;
  262.                      fs.write(buffer,0,byteread);
  263.                      if(change)
  264.                              sfs.write(buffer,0,byteread);
  265.                      System.out.println("\t\t当前下载文件:"+url+"\t当前大小:"+bytesum);
  266.             }
  267.             if(change)
  268.                     sfs.close();
  269.             fs.close();
  270.             instream.close();
  271.             
  272.             if(change)
  273.             {
  274.                 //处理图片
  275.                     ImageUtil.resize(curpath.toString()+dir,curpath.toString()+dir,160,200);
  276.                           ImageUtil.resize(curpath.toString()+"small_"+dir,curpath.toString()+"small_"+dir,80,100);
  277.             }
  278.         }
  279.        
  280.         private class MyThread extends Thread
  281.         {
  282.                 private String downloadurl;
  283.                 private String picurl;
  284.                 private BufferedWriter bwp;
  285.                 private String doctorname;
  286.                
  287.                 public MyThread(Elements info,String picurl,BufferedWriter bwp,int i,Elements eles)
  288.                 {
  289.                         downloadurl=info.get(0).select("img").attr("abs:src");
  290.                         this.picurl=picurl;
  291.                         this.bwp=bwp;
  292.                         doctorname=eles.get(i).text();
  293.                 }
  294.                
  295.                 @Override
  296.                 public void run()
  297.                 {
  298.                         threadnum++;
  299.                         try
  300.                         {
  301.                                 downloadImage(downloadurl,picurl,true);
  302.                         }
  303.                         catch(Exception e)
  304.                         {
  305.                                 try
  306.                                 {
  307.                                         bwp.write("无头像:"+doctorname+"\n");
  308.                                 }
  309.                                 catch (IOException e1)
  310.                                 {
  311.                                         // TODO Auto-generated catch block
  312.                                         e1.printStackTrace();
  313.                                 }
  314.                         }
  315.                         finally
  316.                         {
  317.                                 threadnum--;
  318.                         }
  319.                 }
  320.         }
  321.        
  322.         public void processYisheng(Elements eles) throws Exception
  323.         {
  324.                 FileOutputStream fos=new FileOutputStream("名医大全.xml");
  325.                 OutputStreamWriter osw=new OutputStreamWriter(fos,"UTF-8");
  326.                 BufferedWriter bw=new BufferedWriter(osw);
  327.                 bw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  328.                 bw.write(c("<doctors>\n"));
  329.                 String fatherkeshiname="";
  330.                
  331.                 FileOutputStream fosp=new FileOutputStream("其他信息.xml");
  332.                 OutputStreamWriter oswp=new OutputStreamWriter(fosp);
  333.                 BufferedWriter bwp=new BufferedWriter(oswp);       
  334.                
  335.                 for(int i=0;i<eles.size();i++)
  336.                 {
  337.                         Thread.sleep(200);
  338.                         System.out.println(eles.get(i).attr("abs:href"));
  339.                         Document curdoc;
  340.                         try
  341.                         {
  342.                                 curdoc = Jsoup.connect(eles.get(i).attr("abs:href")).timeout(0).get();
  343.                         }
  344.                         catch (Exception e1)
  345.                         {
  346.                                 // TODO Auto-generated catch block
  347.                                 e1.printStackTrace();
  348.                                 i--;
  349.                                 continue;
  350.                         }
  351.                         Elements temp1=curdoc.select("a[style=color:#0053a3;]");
  352.                         if(temp1.size() < 2)//竟然使用了个人主页!!!
  353.                         {
  354.                                 bwp.write("个人主页:"+eles.get(i).text()+"\n");
  355.                                 continue;
  356.                         }

  357.                         String curfather=temp1.get(temp1.size()-2).text();
  358.                         System.out.println("father:"+curfather);
  359.                         Elements info=curdoc.select("td[style=padding:6px 0px;] table tbody tr td table tbody tr").get(0).children();
  360.                         String picurl=info.get(0).select("img").attr("src");
  361.                         int index=picurl.lastIndexOf('/');
  362.                         String spicurl=picurl.substring(0,index+1)+"small_"+picurl.substring(index+1);
  363.                         if(spicurl.charAt(0) == '/')
  364.                                 spicurl=spicurl.substring(1);
  365.                        
  366.                         if(i == 0)
  367.                         {
  368.                                 bw.write(c("\t<"+curfather+">\n"));
  369.                                 fatherkeshiname=curfather;
  370.                         }
  371.                         else if(!fatherkeshiname.equals(curfather))
  372.                         {
  373.                                 bw.write(c("\t</"+fatherkeshiname+">\n"));
  374.                                 fatherkeshiname=curfather;
  375.                                 bw.write(c("<"+fatherkeshiname+">\n"));
  376.                         }
  377.                        
  378.                         bw.write(c("\t\t<doctor>\n"));
  379.                         bw.write(c("\t\t\t<name>"+eles.get(i).text()+"</name>\n"));
  380.                         System.out.println(eles.get(i).text());
  381.                         bw.write(c("\t\t\t<id></id>\n"));
  382.                         Elements inner=info.get(2).children();
  383.                         bw.write(c("\t\t\t<summary>"+inner.get(2).text()+getProperText(inner.get(4).text())+"</summary>\n"));
  384.                         String doctorname=eles.get(i).text();
  385.                         bw.write(c("\t\t\t<detailurl>"+doctorname+".htm</detailurl>\n"));
  386.                        
  387.                         while(threadnum > 2)
  388.                         {
  389.                                 Thread.sleep(1000);
  390.                         }
  391.                         new MyThread(info,picurl,bwp,i,eles).start();
  392.                        
  393.                         bw.write(c("\t\t\t<smallpicurl>"+spicurl+"</smallpicurl>\n"));
  394.                         bw.write(c("\t\t\t<usefulinfourl>"+doctorname+".xml</usefulinfourl>\n"));//排班、评价、,,,
  395.                         bw.write(c("\t\t</doctor>\n"));
  396.                        
  397.                         if(i == eles.size()-1)
  398.                         {
  399.                                 bw.write(c("\t</"+curfather+">\n"));
  400.                         }
  401.                        
  402.                         FileOutputStream infos=new FileOutputStream(doctorname+".htm");
  403.                         OutputStreamWriter inosw=new OutputStreamWriter(infos,"UTF-8");
  404.                         BufferedWriter inbw=new BufferedWriter(inosw);
  405.                         inbw.write(c("<?xml version="1.0" encoding="utf-8"?>\n"));
  406.                         inbw.write(c("<!DOCTYPE html PUBLIC "-//WAPFORUM//DTD XHTML Mobile 1.0//EN""http://www.wapforum.org/DTD/xhtml-mobile10.dtd">\n"));
  407.                         inbw.write(c("<html xmlns="http://www.w3.org/1999/xhtml">\n"));
  408.                         inbw.write(c("<head><style type="text/css">body{font-size:medium;line-height:1.5em;text-align:left}</style><title>"+doctorname+"</title></head>\n"));
  409.                         inbw.write(c("<body>\n\t<div>\n"));
  410.                        
  411.                         for(Element el:info.select("img"))
  412.                         {
  413.                                 final String url=el.attr("abs:src");
  414.                                 final String dst=el.attr("src");
  415.                                
  416.                                 while(threadnum > 10)
  417.                                 {
  418.                                         Thread.sleep(1000);
  419.                                 }
  420.                                
  421.                                 new Thread()
  422.                                 {
  423.                                         @Override
  424.                                         public void run()
  425.                                         {
  426.                                                 threadnum++;
  427.                                                 try
  428.                                                 {
  429.                                                         downloadImage(url,dst,false);
  430.                                                 }
  431.                                                 catch (Exception e)
  432.                                                 {
  433.                                                         // TODO Auto-generated catch block
  434.                                                         e.printStackTrace();
  435.                                                 }
  436.                                                 finally
  437.                                                 {
  438.                                                         threadnum--;
  439.                                                 }
  440.                                         }
  441.                                 }.start();
  442.                         }
  443.                        
  444.                         inbw.write(c("\t\t"+info.html().replace("/picture","picture")+"\n"));
  445.                         inbw.write(c("\t</div>\n</body>\n</html>"));
  446.                         inbw.close();
  447.                         inosw.close();
  448.                         infos.close();
  449.                 }
  450.                
  451.                 bw.write(c("</doctors>\n"));
  452.                
  453.                 bw.close();
  454.                 osw.close();
  455.                 fos.close();
  456.                
  457.                 bwp.close();
  458.                 oswp.close();
  459.                 fosp.close();
  460.         }
  461.        
  462.         private String getProperText(String src)
  463.         {
  464.                 src=src.replace("????","");
  465.                 if(src.length() > 128)
  466.                 {
  467.                         StringBuilder sb=new StringBuilder(src.substring(0, 128));
  468.                         for(int i=128;i<src.length();i++)
  469.                         {
  470.                                 char ch=src.charAt(i);
  471.                                 sb.append(ch);
  472.                                 if(ch == ',' || ch == '。' || ch == '、')
  473.                                 {
  474.                                         break;
  475.                                 }
  476.                         }
  477.                         sb.setCharAt(sb.length()-1,'。');
  478.                         return sb.toString();
  479.                 }
  480.                 else
  481.                         return src;
  482.         }
  483.        
  484.         public static void main(String[] args) throws Exception
  485.         {       
  486.                 new jsph();
  487.         }
  488. }


复制代码


点评

好!赞一个  详情 回复 发表于 2014-4-7 12:58
回复 赞! 1 靠! 0

使用道具 举报

发表于 2014-4-7 00:07:44 | 显示全部楼层
跪求4字符的TAB啊

点评

啥意思  详情 回复 发表于 2014-4-7 12:44
回复 赞! 靠!

使用道具 举报

发表于 2014-4-7 12:58:04 | 显示全部楼层
元始天尊 发表于 2014-4-7 04:44
啥意思
修改后的jsph.java

好!赞一个
回复 赞! 靠!

使用道具 举报

本版积分规则

QQ|Archiver|小黑屋|技术宅的结界 ( 滇ICP备16008837号 )|网站地图

GMT+8, 2024-12-22 16:26 , Processed in 0.040566 second(s), 29 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表