[1]字符串按中文符占3位进行指定长度剪切[2]Double类型截取指定长度(指定长度=整数位+小数位)

 1     /** 将中文字符串剪切为在当前db2(编码GBK)中所占用的长度*/
 2     public String cutStringForDb2(String src,Integer size) {
 3         int len = src.length();
 4         int res_len = 0;
 5         StringBuilder res_b = new StringBuilder();
 6         for (int i = 0 ; i < len; i++) {
 7             if (isChinese(src.charAt(i))) {
 8                 res_len+=3;
 9             } else {
10                 res_len+=1;
11             }
12             if (res_len>size) {
13                 break;
14             } else {
15                 res_b.append(src.charAt(i));
16             }
17         }
18         return res_b.toString();
19     }
20
21     public boolean isChinese(char c) {
22         Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
23         if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
24                 || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_B
25                 || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS
26                 || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION) {
27             return true;
28         }
29         return false;
30     }
31
32     public Double cutDouble(String src,Integer intValue,Integer pointValue) {
33         if (src.length() > intValue) {
34             if (src.matches("[0-9]*\\.[0-9]*")) {
35                 String[] strs = src.split("\\.");
36                 StringBuilder res = new StringBuilder().append(strs[0].length()>intValue?
37                         strs[0].substring(0, intValue):strs[0]);
38                 res.append(strs[1].length()>pointValue?strs[1].substring(0, pointValue):strs[1]);
39                 return Double.parseDouble(res.toString());
40             } else if (src.matches("[0-9]*")){
41                 return Double.parseDouble(src.substring(0, intValue));
42             } else {
43                 return 0.0D;
44             }
45         } else {
46             return Double.parseDouble(src);
47         }
48     }
时间: 2024-08-10 17:20:31

[1]字符串按中文符占3位进行指定长度剪切[2]Double类型截取指定长度(指定长度=整数位+小数位)的相关文章

double类型的小数,四舍五入保留两位小数

import java.math.BigDecimal; public class Kewai{ public static void main(String[] args) { double f = 3.1415927; BigDecimal b = new BigDecimal(f); double f1 = b.setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue(); System.out.println(f1); } } 原文地址:http

JS判断字符串长度(英文占1个字符,中文汉字占2个字符)

//计算字符串长度(英文占1个字符,中文汉字占2个字符) 方法一: String.prototype.gblen = function() { var len = 0; for (var i=0; i<this.length; i++) { if (this.charCodeAt(i)>127 || this.charCodeAt(i)==94) { len += 2; } else { len ++; } } return len; } 方法二: function strlen(str){

[转载]PHP 字符串替换中文

$a = "Car 神"; $result = preg_replace('/([\x80-\xff]*)/i','',$a); var_dump($result); 参考链接:php字符串去掉中文

Python格式化字符串的替代符与转义字符

                                               Python格式化字符串的替代符以及含义     符   号     说     明       %c  格式化字符及其ASCII码       %s  格式化字符串       %d  格式化整数       %u  格式化无符号整型       %o  格式化无符号八进制数       %x  格式化无符号十六进制数       %X  格式化无符号十六进制数(大写)       %f  格式化浮点

固本培元之二:字符串和转义符

字符串string. 1.不可变性:一但被赋值就会再变化,每次字符串的变化都会把指针指向新的字符串. 2.可以用:字符串之间可以用串联运算符(+)产生出新的字符串. 3.常用属性:Length表示字符串长度,得到Int类型. 4.常用方法: Trim():去白字: ToUpper():转换为大写形式: ToLower():转换为小写形式; Split():分割 Replace():替换 Remove():移除 LastIndexOf():最后一次出现位置 IsNullOrEmpty:是null或

判断字符串是中文或者英文

import java.util.regex.Matcher; import java.util.regex.Pattern; /** * * <p> * ClassName ShowChineseInUnicodeBlock * </p> * <p> * Description 提供判断字符串是中文或者是英文的一种思路 * </p> * * @author wangxu [email protected] * <p> * Date 2014-9

过滤字符串中中文

1 USE [master]  2 GO 3 /****** Object:  UserDefinedFunction [dbo].[RemoveCharRep]    Script Date: 04/06/2016 17:34:54 ******/ 4 SET ANSI_NULLS ON 5 GO 6 SET QUOTED_IDENTIFIER ON 7 GO 8 --============================== 9 --过滤掉字符串中中文字符 @s 为输入字符串10 --==

十六进制Unicode编码字符串与中文字符串的相互转换

图书馆客户端项目中遇到的一个问题,得到的URL 是这样的 String baseurl = "http://innopac.lib.xjtu.edu.cn/availlim/search~S1*chx?/X{u848B}{u4ECB}{u77F3}&searchscope=1&SORT=DZ/X{u848B}{u4ECB}{u77F3}&searchscope=1&SORT=DZ&extended=0&SUBKEY=%E8%92%8B%E4%BB%

把字符串按照分割符分解成不同的部分

select regexp_substr('A,B,C,D,E', '[^,]+', 1, level, 'i') as str from dual connect by level <= length('A,B,C,D,E') - length(regexp_replace('A,B,C,D,E', ',', '')) + 1;把字符串按照分割符分解成不同的部分