Java 判断是否为汉字 判断是否为乱码 判断字符串是否为双整型数字 整数 数字

/**
  * 判断是否为汉字
  * 
  * @param str
  * @return
  */
 public static boolean isGBK(String str) {
  char[] chars = str.toCharArray();
  boolean isGBK = false;
  for (int i = 0; i < chars.length; i++) {
   byte[] bytes = ("" + chars[i]).getBytes();
   if (bytes.length == 2) {
    int[] ints = new int[2];
    ints[0] = bytes[0] & 0xff;
    ints[1] = bytes[1] & 0xff;
    if (ints[0] >= 0x81 && ints[0] <= 0xFE && ints[1] >= 0x40
      && ints[1] <= 0xFE) {
     isGBK = true;
     break;
    }
   }
  }
  return isGBK;
 }

/**
  * 判断是否为乱码
  * 
  * @param str
  * @return
  */
 public static boolean isMessyCode(String str) {
  for (int i = 0; i < str.length(); i++) {
   char c = str.charAt(i);
   // 当从Unicode编码向某个字符集转换时,如果在该字符集中没有对应的编码,则得到0x3f(即问号字符?)
   //从其他字符集向Unicode编码转换时,如果这个二进制数在该字符集中没有标识任何的字符,则得到的结果是0xfffd
   //System.out.println("--- " + (int) c);
   if ((int) c == 0xfffd) {
    // 存在乱码
    //System.out.println("存在乱码 " + (int) c);
    return true;
   }
  }
  return false; 
 }

/**
  * 判断字符串是否为双整型数字
  * 
  * @param str
  * @return
  */
 public static boolean isDouble(String str) {
  if (StringUtil.isNullOrEmpty(str)) {
   return false;
  }
  Pattern p = Pattern.compile("-*\\d*.\\d*");
  // Pattern p = Pattern.compile("-*"+"\\d*"+"."+"\\d*");
  return p.matcher(str).matches();
 }

/**
  * 判断字符串是否为整字
  * 
  * @param str
  * @return
  */
 public static boolean isNumber(String str) {
  if (StringUtil.isNullOrEmpty(str)) {
   return false;
  }
  Pattern p = Pattern.compile("-*\\d*");
  return p.matcher(str).matches();
 }
 
 /**
  * 判断是否为数字
  * 
  * @param str
  * @return
  */
 public static boolean isNumeric(String str)   
 {   
         Pattern pattern = Pattern.compile("[0-9]*");   
         Matcher isNum = pattern.matcher(str);   
        if( !isNum.matches() ) {   
           return false;   
         }   
        return true;   
 }

需要导入 java.util.regex.Pattern 和 java.util.regex.Matcher

from:http://hi.baidu.com/zdz8207/item/13abe809f904c718eafe38d5

时间: 2024-10-15 20:03:40

Java 判断是否为汉字 判断是否为乱码 判断字符串是否为双整型数字 整数 数字的相关文章

求一个整型数字中有没有相同的部分,例如12386123这个整型数字中相同的部分是123,相同的部分至少应该是2位数,如果有相同部分返回1,如果没有则返回0。方法是先将整型数字转换到数组中,再判断。函数为 int same(int num)其中num是输入的整型数字

import java.util.ArrayList; import java.util.List; import java.util.Scanner; public class Test { public static void main(String[] args) { /** * 2.求一个整型数字中有没有相同的部分,例如12386123这个整型数字中相同的部分是123, * 相同的部分至少应该是2位数,如果有相同部分返回1,如果没有则返回0. * 方法是先将整型数字转换到数组中,再判断.

9. Palindrome Number(判断整型数字是否是回文,直接暴力即可)

Determine whether an integer is a palindrome. Do this without extra space. 暴力的时候,注意奇数偶数. 1 class Solution: 2 def isPalindrome(self, x): 3 """ 4 :type x: int 5 :rtype: bool 6 """ 7 x =str(x) 8 9 if(len(x)%2!=0):#数 10 for i in

C#怎么判断字符是不是汉字

支持并尊重原创!原文地址:http://jingyan.baidu.com/article/2c8c281deb79ed0008252af1.html 判断一个字符是不是汉字通常有三种方法,第1种用 ASCII 码判断,第2种用汉字的 UNICODE 编码范围判 断,第3种用正则表达式判断,下面是具体方法. 1.用ASCII码判断 在 ASCII码表中,英文的范围是0-127,而汉字则是大于127,根据这个范围可以判断,具体代码如下: 调用方法:CheckStringChinese("是不是汉字

java小练习:.根据输入的月份,判断该月份有多少天

package practiceGO; import java.util.Scanner; /*  * 2.根据输入的月份,判断该月份有多少天  */ public class Cto { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("输入月份:"); int month = sc.nextInt(); switch (month) {

java之过滤中文汉字

/** * 判断是否包含汉字 * @param str * @return */ public static boolean isContainChinese(String str) { Pattern p = Pattern.compile("[\u4e00-\u9fa5]"); Matcher m = p.matcher(str); if (m.find()) { return true; } return false; }

sgu139Help Needed!判断15数码是否有解,以及判断N数码是否有解的推论

是这样的,要你判断一个15数码是否有解. 我不会,找了这样一个方法. 将16个数按出现顺序存放在一维数组里面, 然后累加每个数的逆序对数目, 还要加上0到终态的曼哈顿距离,得到一个数x. 由于最后的状态,整个图的逆序对数目是15, 是个奇数,于是,如果x也是奇数, 那么这个15数码就有解, 否则无解. 其它各种数码,都按照此法解就是了, 我的代码如下: #include<iostream> using namespace std; int main() { int map[16],ans=0;

java随机动态生成汉字验证码图片的实例代码分享

原创不易,转载请注明出处:java随机动态生成汉字验证码图片的实例代码分享 代码下载地址:http://www.zuidaima.com/share/1809721113234432.htm 汉字验证码实现原理 将汉字和干扰线生成图片并将汉字保存到session,前台获取每次生成验证码图片并用文本框值和session值比较,功能相对来说还是比较简单的. 效果图,如下: 验证成功后: java随机动态生成汉字验证码图片的实例代码分享

Java随机生成中文汉字(使用高位低位转码)

1 Java随机生成中文汉字 2 /** 3 * 原理是从汉字区位码找到汉字.在汉字区位码中分高位与底位, 且其中简体又有繁体.位数越前生成的汉字繁体的机率越大. 4 * 所以在本例中高位从171取,底位从161取, 去掉大部分的繁体和生僻字.但仍然会有!! 5 * 6 */ 7 @Test 8 public void create() throws Exception { 9 String str = null; 10 int hightPos, lowPos; // 定义高低位 11 Ran

js 日期比较大小,js判断日期是否在区间内,js判断时间段是否在另外一个时间段内

/** * 日期解析,字符串转日期 * @param dateString 可以为2017-02-16,2017/02/16,2017.02.16 * @returns {Date} 返回对应的日期对象 */ function dateParse(dateString){ var SEPARATOR_BAR = "-"; var SEPARATOR_SLASH = "/"; var SEPARATOR_DOT = "."; var dateArr