亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? rangeaddress.java

?? java 報表 to office文檔: 本包由java語言開發
?? JAVA
字號:
/* ====================================================================   Copyright 2002-2004   Apache Software Foundation   Licensed under the Apache License, Version 2.0 (the "License");   you may not use this file except in compliance with the License.   You may obtain a copy of the License at       http://www.apache.org/licenses/LICENSE-2.0   Unless required by applicable law or agreed to in writing, software   distributed under the License is distributed on an "AS IS" BASIS,   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.   See the License for the specific language governing permissions and   limitations under the License.==================================================================== */package org.apache.poi.hssf.util;/** * Title:        Range Address <P> * Description:  provides connectivity utilities for ranges<P> * * * REFERENCE:  <P> * @author IgOr KaTz && EuGeNe BuMaGiN (Tal Moshaiov) (VistaPortal LDT.)@version 1.0 */public class RangeAddress {  final static int WRONG_POS  = -1;  final static int MAX_HEIGHT = 66666;  final static char SO_FORMNAME_ENCLOSURE =  '\'';  String m_sheetName;  String m_cellFrom;  String m_cellTo;  /**   * Accepts an external reference from excel.   * <p>   * i.e. Sheet1!$A$4:$B$9   * @param _url   */    public RangeAddress (String _url) {    init (_url);  }    public RangeAddress (int _startCol, int _startRow, int _endCol, int _endRow) {    init (numTo26Sys (_startCol) + _startRow + ":"    + numTo26Sys (_endCol) + _endRow);  }    /**   *    * @return String <b>note: </b> All absolute references are removed   */  public String getAddress (){    String result = "";    if(m_sheetName != null)      result += m_sheetName+"!";    if(m_cellFrom != null){      result += m_cellFrom;      if(m_cellTo != null)        result += ":" + m_cellTo;    }    return result;  }      public String getSheetName (){    return m_sheetName;  }    public String getRange (){    String result = "";    if(m_cellFrom != null){      result += m_cellFrom;      if(m_cellTo != null)        result += ":" + m_cellTo;    }    return result;  }    public  boolean isCellOk (String _cell){    if (_cell != null){      if ( (getYPosition (_cell) != WRONG_POS) &&      (getXPosition (_cell) != WRONG_POS) )        return true;      else        return false;    } else      return false;  }    public  boolean isSheetNameOk (){    return isSheetNameOk (m_sheetName);  }    private  static boolean intern_isSheetNameOk (String _sheetName, boolean _canBeWaitSpace){    for (int i = 0  ; i < _sheetName.length (); i++){      char ch = _sheetName.charAt (i);      if (! (Character.isLetterOrDigit (ch) || (ch == '_')||      _canBeWaitSpace&&(ch == ' '))){        return false;      }    }    return true;  }    public  static boolean isSheetNameOk (String _sheetName){    boolean res = false;    if ( ( _sheetName != null) && !_sheetName.equals ("")){      res = intern_isSheetNameOk (_sheetName,true);    }else      res = true;    return res;  }      public String getFromCell (){    return m_cellFrom;  }    public String getToCell (){    return m_cellTo;  }    public int getWidth (){    if(m_cellFrom != null && m_cellTo != null){      int toX    =  getXPosition (m_cellTo);      int fromX  =  getXPosition (m_cellFrom);      if ((toX == WRONG_POS) || (fromX == WRONG_POS)){        return 0;      }else        return toX - fromX + 1;    }    return 0;  }    public int getHeight (){    if(m_cellFrom != null && m_cellTo != null){      int toY    =  getYPosition (m_cellTo);      int fromY  =  getYPosition (m_cellFrom);      if ((toY == WRONG_POS) || (fromY == WRONG_POS)){        return 0;      }else        return toY - fromY + 1;    }    return 0;  }    public void setSize (int _width, int _height){    if(m_cellFrom == null)      m_cellFrom = "a1";    int tlX, tlY, rbX, rbY;    tlX = getXPosition (m_cellFrom);    tlY = getYPosition (m_cellFrom);    m_cellTo = numTo26Sys (tlX + _width - 1);    m_cellTo += String.valueOf (tlY + _height - 1);  }    public boolean hasSheetName (){    if(m_sheetName == null)      return false;    return true;  }    public boolean hasRange (){    if(m_cellFrom == null || m_cellTo == null)      return false;    return true;  }    public boolean hasCell (){    if(m_cellFrom == null)      return false;    return true;  }    private void init (String _url){    _url = removeString(_url, "$");    _url = removeString(_url, "'");        String[] urls = parseURL (_url);    m_sheetName = urls[0];    m_cellFrom = urls[1];    m_cellTo = urls[2];    //What if range is one celled ?    if (m_cellTo == null){      m_cellTo = m_cellFrom;    }            //Removing noneeds characters    m_cellTo    = removeString(m_cellTo,".");          }    private String[] parseURL (String _url){    String[] result = new String[3];    int index = _url.indexOf(':');    if (index >= 0) {      String fromStr = _url.substring(0, index);      String toStr = _url.substring(index+1);      index = fromStr.indexOf('!');      if (index >= 0) {        result[0] = fromStr.substring(0, index);        result[1] = fromStr.substring(index+1);      } else {        result[1] = fromStr;      }      index = toStr.indexOf('!');      if (index >= 0) {        result[2] = toStr.substring(index+1);       } else {        result[2] = toStr;       }         } else {      index = _url.indexOf('!');      if (index >= 0) {        result[0] = _url.substring(0, index);        result[1] = _url.substring(index+1);      } else {        result[1] = _url;      }    }    return result;  }    public int getYPosition (String _subrange){    int result = WRONG_POS;    _subrange = _subrange.trim ();    if (_subrange.length () != 0){      String digitstr = getDigitPart (_subrange);      try {        result = Integer.parseInt (digitstr);        if (result  > MAX_HEIGHT){          result = WRONG_POS;        }      }      catch (Exception ex) {                result = WRONG_POS;      }    }    return result;  }    private static boolean isLetter (String _str){    boolean res = true;    if ( !_str.equals ("") ){      for (int i = 0  ; i < _str.length (); i++){        char ch = _str.charAt (i);        if (! Character.isLetter (ch)){          res = false;          break;        }      }    }else      res = false;    return res;  }    public int getXPosition (String _subrange){    int result = WRONG_POS;    String tmp = filter$ (_subrange);    tmp = this.getCharPart (_subrange);    // we will process only 2 letters ranges    if (isLetter (tmp) && ((tmp.length () == 2)|| (tmp.length () == 1) )){      result =  get26Sys (tmp);    }    return result;  }    public String getDigitPart (String _value){    String result = "";    int digitpos = getFirstDigitPosition (_value);    if(digitpos >= 0){      result = _value.substring (digitpos);    }    return result;  }    public String getCharPart (String _value){    String result = "";    int digitpos = getFirstDigitPosition (_value);    if(digitpos >= 0){      result = _value.substring (0, digitpos);    }    return result;  }    private String filter$ (String _range){    String res = "";    for (int i = 0 ; i < _range.length () ; i++){      char ch = _range.charAt (i);      if  ( ch != '$' ){        res = res + ch;      }    }    return res;  }    private int getFirstDigitPosition (String _value){    int result = WRONG_POS;    if(_value != null && _value.trim ().length () == 0){      return result;    }    _value = _value.trim ();    int length = _value.length ();    for(int i = 0; i < length; i++){      if(Character.isDigit (_value.charAt (i))){        result = i;        break;      }    }    return result;  }    public int get26Sys (String _s){    int sum = 0;    int multiplier = 1;    if (_s != "") {      for (int i = _s.length ()-1 ; i >= 0 ; i--){        char ch = _s.charAt (i);        int val =  Character.getNumericValue (ch) - Character.getNumericValue ('A')+1;        sum = sum + val * multiplier;        multiplier = multiplier * 26;      }      return sum;    }    return WRONG_POS;  }    public String numTo26Sys (int _num){    int sum = 0;    int reminder;    String s ="";    do{      _num --;      reminder = _num % 26;      int val =  65 + reminder;      _num = _num / 26;      s = (char)val + s; // reverce    }while(_num > 0);    return s;  }      public String replaceString(String _source , String _oldPattern,    String _newPattern){        StringBuffer res = new StringBuffer(_source);        int pos = -1;                while ((pos = res.toString().indexOf(_oldPattern, pos)) > -1){            res.replace(pos, pos + _oldPattern.length(), _newPattern);        }                return res.toString();    }        public String removeString(String _source, String _match){        return replaceString(_source, _match, "");    }  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕欧美一区| 日韩在线一二三区| 成人免费在线视频| 亚洲乱码日产精品bd| 色菇凉天天综合网| 久久久久久麻豆| 色综合久久天天| 欧美高清视频不卡网| 91精品国产综合久久久久久久 | 欧美日韩精品一区二区| 69精品人人人人| 欧美不卡一区二区三区四区| 久久久久久免费| 亚洲免费观看高清完整版在线观看 | 日韩精品免费专区| 国产一区二区成人久久免费影院 | 亚洲视频精选在线| 亚洲国产日韩精品| 久久精品国产成人一区二区三区 | 91片黄在线观看| 91 com成人网| 欧美激情一区三区| 一区二区欧美国产| 美国三级日本三级久久99| 国产69精品久久久久毛片| 色综合一区二区三区| 亚洲另类中文字| 一片黄亚洲嫩模| 国产精品69久久久久水密桃| 亚洲欧美日本韩国| 日本在线不卡一区| 99久久久久久| 日韩欧美一区二区在线视频| 成人免费一区二区三区在线观看| 天堂一区二区在线| av一本久道久久综合久久鬼色| 欧美日韩精品一区二区三区| 日本一区二区三级电影在线观看 | 在线播放91灌醉迷j高跟美女| 国产日韩影视精品| 日韩不卡一二三区| 91网页版在线| 日韩一区二区三区在线| 国产日韩欧美精品一区| 美日韩一区二区三区| 色噜噜狠狠成人网p站| 国产婷婷色一区二区三区| 天堂在线一区二区| 欧美无人高清视频在线观看| 久久老女人爱爱| 老汉av免费一区二区三区| 91国偷自产一区二区三区观看 | 久久久www成人免费无遮挡大片 | 视频一区二区不卡| 精品日韩一区二区三区| 国产精品亚洲一区二区三区妖精| 国产精品护士白丝一区av| 91搞黄在线观看| 亚洲成av人片在线| 久久综合久久综合九色| 成人国产电影网| 亚洲午夜激情网页| 欧美精品一区二区蜜臀亚洲| 成人黄色在线网站| 亚洲丶国产丶欧美一区二区三区| 91精品国产全国免费观看| 国产一区欧美日韩| 亚洲欧美日韩系列| 欧美电影免费观看高清完整版在线| 国产美女在线精品| 亚洲国产精品麻豆| 久久精品一区二区三区av| 欧美综合在线视频| 国产精品综合在线视频| 亚洲一区二区三区在线看| 久久丝袜美腿综合| 欧美丝袜丝交足nylons图片| 激情综合网av| 亚洲高清不卡在线| 国产欧美精品一区二区色综合| 欧美日本一区二区| 欧美日韩国产高清一区二区三区 | 午夜免费久久看| 国产欧美视频在线观看| 欧美日韩精品免费| 不卡一区二区三区四区| 久久99精品久久久久婷婷| 亚洲精品视频一区二区| 国产情人综合久久777777| 欧美在线看片a免费观看| 国产激情一区二区三区| 美女诱惑一区二区| 亚洲女性喷水在线观看一区| 国产日韩精品久久久| 日韩三级视频中文字幕| 欧亚一区二区三区| 不卡电影一区二区三区| 国产尤物一区二区在线| 亚洲风情在线资源站| 亚洲欧美偷拍卡通变态| 国产亚洲精品aa| 91精品国产色综合久久不卡电影| 99久久久无码国产精品| 国模无码大尺度一区二区三区| 亚洲高清免费观看高清完整版在线观看| 国产日韩影视精品| 精品国产乱码久久久久久图片| 欧美日韩国产综合草草| 精品视频在线免费| www.一区二区| 成人黄色片在线观看| 国产成人综合网站| 国模大尺度一区二区三区| 免费一级欧美片在线观看| 五月天中文字幕一区二区| 午夜视频一区二区| 日本成人在线网站| 裸体健美xxxx欧美裸体表演| 另类综合日韩欧美亚洲| 麻豆精品蜜桃视频网站| 日韩黄色一级片| 日产欧产美韩系列久久99| 美女视频一区二区三区| 九色porny丨国产精品| 成人午夜短视频| 成人午夜又粗又硬又大| 成人美女视频在线观看18| eeuss鲁片一区二区三区在线观看 eeuss鲁片一区二区三区在线看 | 91视频com| 色婷婷激情综合| 欧美色综合影院| 欧美日韩精品一区二区三区四区| 欧美高清视频在线高清观看mv色露露十八 | 日韩一区二区三区高清免费看看| 日韩一区二区免费在线观看| 69堂精品视频| 久久色成人在线| 中文字幕一区在线| 亚洲成av人在线观看| 美国十次了思思久久精品导航| 国产精品一区二区男女羞羞无遮挡 | 91在线国产福利| 欧美日韩高清在线| 久久蜜桃一区二区| 亚洲色图在线看| 日本免费在线视频不卡一不卡二 | va亚洲va日韩不卡在线观看| 91麻豆文化传媒在线观看| 777午夜精品免费视频| 26uuu精品一区二区| 亚洲欧洲一区二区在线播放| 香蕉加勒比综合久久| 国产成人亚洲综合a∨婷婷图片| 91视视频在线观看入口直接观看www | 91美女视频网站| 欧美一区二区日韩| 国产亚洲一区字幕| 成人欧美一区二区三区| 毛片不卡一区二区| 东方aⅴ免费观看久久av| 欧美三级在线看| 精品国产一区久久| 中文字幕一区二区三区不卡| 久久精品国产亚洲一区二区三区 | 国产精品电影一区二区三区| 午夜视频一区在线观看| 成人黄色软件下载| 国产精品久久三| 三级欧美在线一区| 91在线你懂得| 久久久美女艺术照精彩视频福利播放| 亚洲精品国产高清久久伦理二区| 国产自产视频一区二区三区| 欧美怡红院视频| 国产日韩欧美麻豆| 久久99精品久久只有精品| 欧美在线免费观看视频| 国产精品久久久久久久久动漫 | 日韩欧美一级精品久久| 最近日韩中文字幕| 国产福利一区二区三区视频| 日韩亚洲国产中文字幕欧美| 亚洲午夜精品网| 91伊人久久大香线蕉| 国产欧美一区二区精品忘忧草| 麻豆精品久久久| 91麻豆精品国产综合久久久久久| 亚洲免费在线观看| 高潮精品一区videoshd| 久久午夜老司机| 精品在线免费观看| 7777精品伊人久久久大香线蕉| 亚洲国产一区二区三区 | 亚洲精品国产品国语在线app| 成人精品鲁一区一区二区| 国产欧美一区二区三区沐欲| 国产高清无密码一区二区三区| 久久精品亚洲乱码伦伦中文| 国产乱对白刺激视频不卡| 久久综合久久综合九色|