1. 用java 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。但是要保
packagecom.demo.test;
importjava.util.Scanner;
publicclassMain{
publicstaticvoidmain(String[]args)throwsException{
Scannersc=newScanner(System.in);
//输入字符串
Stringstr=sc.next();
//输入要截取的字节长度
intbyteLength=sc.nextInt();
splitString(str,byteLength);
sc.close();
}
publicstaticvoidsplitString(Stringstr,intbyteLength)throwsException{
//判断待截取的字符串的字节长度是否大于等于输入的字节长度
if(str.getBytes().length>=byteLength){
//将字符串转为字符数组
char[]charArray=str.toCharArray();
Strings="";
for(inti=0;i<byteLength;i++){
//判断当前字符串s的字节长度是否与要截取的字节长度相等,若相等跳出循环
if(s.getBytes().length==byteLength){
break;
//判断当前字符串s的字节长度是否小于要截取的字节长度,若小于继续拼接字符串
}elseif(s.getBytes().length<byteLength){
s+=charArray[i];
}else{
//当前字符串字节长度大于要截取的字节长度,舍弃最后一个字符
s=s.substring(0,i-1);
break;
}
}
System.out.println(s);
}else{
System.out.println("输入的字节长度不能大于字符串的字节长度");
}
}
}
2. JAVA中读取一段某个字节到某个字节的字符串
不可以,你可以这样写String str="我是中国人";
int indexStr=str.indexOf("是中国");
String subStr=str.substring(indexStr-1,3);
这时subStr的值应该为“是专中国”这三个属字
3. java 按字节截取字符串问题
关于你的问题的问题:1. 到底按字节截还是字符截?按字节的话必须先将字符串转为byte array 2.很长是多长,多次是多少次?现在计算机的内存及计算能力你不要低估了,在一个普通的笔记本上,对于10M长的字符串,进行1百万次随机位置的substring,不到1秒。3.如果真是很长很多次,那你要对你substring的顺利研究下,看能不能尽量挨着访问,从内存访问(缺页)方面来提高一点速度,不过这需求确实确实好难见。
试试下面程序的运行速度吧:
import java.util.*;
public class Study {
public static void main(String[] args) {
StringBuilder sb = new StringBuilder();
System.out.println(System.currentTimeMillis());
for(int i = 0; i < 1000000; i++){
sb.append("1234567890");
}
System.out.println(System.currentTimeMillis());
String str = sb.toString();
Random rand = new Random();
for(int i = 0; i < 1000000; i++){
int beg = rand.nextInt(5000000);
int end = rand.nextInt(5000000)+beg;
str.substring(beg, end);
}
System.out.println(System.currentTimeMillis());
}
}
4. java 操作字符串时,怎么获得整个字符串4字节长度
字节么??一个汉字2个字节啊,就是这专个特殊情况吧
privateintnative2ascii(Stringnativecode)
{
属char[]natives=nativecode.toCharArray();
intlen=0;
for(inti=0;i<natives.length;i++)
{
intcode=String.valueOf(natives[i]).codePointAt(0);
if(code>127)
{
StringcharAscii=Integer.toHexString(code);
charAscii="0000".substring(charAscii.length(),4)+charAscii;
len+=2;
}
else
{
len++;
}
}
returnlen;
}
5. java 如何判断一个字符串中有并找到4字节的字符。
int indexOf(String str)返回指定字符在此字符串中第一次出现的位置.
如果不是你要的答案,建议去看看JDK中的Sting类方面的东西。
6. (java)如何获取字符串的字节数!
字符串是可以转变成字节数组,然后统计一下字节数组的长度即可,参考专如下代码:
Java语言中属,中文字符所占的字节数取决于字符的编码方式,一般情况下,采用ISO8859-1编码方式时,一个中文字符与一个英文字符一样只占1个字节;采用GB2312或GBK编码方式时,一个中文字符占2个字节;而采用UTF-8编码方式时,一个中文字符会占3个字节。
public static void main(String []args) throws UnsupportedEncodingException {
// 运行结果:2
System.out.println("测试".getBytes("ISO8859-1").length);
// 运行结果:4
System.out.println("测试".getBytes("GB2312").length);
// 运行结果:4
System.out.println("测试".getBytes("GBK").length);
// 运行结果:6
System.out.println("测试".getBytes("UTF-8").length);
}
7. JAVA中如何过滤字符串里面特殊字符
class test
{
public static void main(String []args)
{
String a = "1111-22-33 13:15:46",b=new String();
int i,j,t;
for(i=0;i<a.length();i++)
if(a.charAt(i)!='-' && a.charAt(i)!=':' && a.charAt(i)!=' ')
b=b+a.charAt(i);
System.out.println(b);
}
}
8. JAVA中如何按字节截取子字符串
substr 方法用于返回一个从指定位置开始的指定长度的子字符串。
语法
stringObject.substr(start [, length ])
9. java,要实现字符串按字节截取的方法
publicintchineseLength(Strings7){
/**
*获取字符串的长度,如果有中文,则每个中文字符计为2位
*
*@paramvalue
*指定的字符串
*@return字符串的长度
*/
intvalueLength=0;
intnumber=0;
Stringchinese="[u0391-uFFE5]";
/*获取字段值的长度,如果含中文字符,则每个中文字符长度为2,否则为1*/
for(intq=0;q<s7.length();q++){
/*获取一个字符*/
Stringtemp=s7.substring(q,q+1);
/*判断是否为中文字符*/
if(temp.matches(chinese)){
/*中文字符长度为2*/
valueLength+=2;
//返回这个字符串中有几个汉字
number+=1;
}else{
/*其他字符长度为1*/
valueLength+=1;
}
}
returnnumber;
}
10. java字符串字节长度截取问题
contentSummanry = contentSummanry.substring(0,100); 这就是说我要截取前面一百个字符
同学 这是最好的截取了 你试试
contentSummanry就是你要去里面截取的字符串 看看这里吧:
public class CutString {
/**
* 判断是否是一个中文汉字
*
* @param c
* 字符
* @return true表示是中文汉字,false表示是英文字母
* @throws UnsupportedEncodingException
* 使用了JAVA不支持的编码格式
*/
public static boolean isChineseChar(char c)
throws UnsupportedEncodingException {
// 如果字节数大于1,是汉字
// 以这种方式区别英文字母和中文汉字并不是十分严谨,但在这个题目中,这样判断已经足够了
return String.valueOf(c).getBytes("GBK").length > 1;
}
/**
* 按字节截取字符串
*
* @param orignal
* 原始字符串
* @param count
* 截取位数
* @return 截取后的字符串
* @throws UnsupportedEncodingException
* 使用了JAVA不支持的编码格式
*/
public static String substring(String orignal, int count)
throws UnsupportedEncodingException {
// 原始字符不为null,也不是空字符串
if (orignal != null && !"".equals(orignal)) {
// 将原始字符串转换为GBK编码格式
orignal = new String(orignal.getBytes(), "GBK");
// 要截取的字节数大于0,且小于原始字符串的字节数
if (count > 0 && count < orignal.getBytes("GBK").length) {
StringBuffer buff = new StringBuffer();
char c;
for (int i = 0; i < count; i++) {
// charAt(int index)也是按照字符来分解字符串的
c = orignal.charAt(i);
buff.append(c);
if (CutString.isChineseChar(c)) {
// 遇到中文汉字,截取字节总数减1
--count;
}
}
return buff.toString();
}
}
return orignal;
}
public static void main(String[] args) {
// 原始字符串
String s = "我ZWR爱JAVA";
System.out.println("原始字符串:" + s);
try {
System.out.println("截取前1位:" + CutString.substring(s, 1));
System.out.println("截取前2位:" + CutString.substring(s, 2));
System.out.println("截取前4位:" + CutString.substring(s, 4));
System.out.println("截取前6位:" + CutString.substring(s, 6));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}