61阅读

excel截取字符串函数-jstl 字符串处理函数

发布时间:2018-03-01 所属栏目:字符串数组

一 : jstl 字符串处理函数

JSTL使用表达式来简化页面的代码,这对一些标准的方法,例如bean的getter/setter方法,请求参数或者context以及session中的数据的访问非常方便,但是我们在实际应用中经常需要在页面调用对象的某些方法,例如我需要调用字符串的length方法来获取字符串的长度时,在以往的开发过程中我们必须把对象先转为String类,然后在调用其length方法,这样的代码繁琐而且容易出错。

因此JSTL内置了几个用于字符串操作的方法,可以直接在表达式中使用,大大的简化了代码,提供代码的可读性。在JSTL的表达是中要使用一个函数,其格式如下

${ns:methodName(args....)}

在使用这些函数之前必须在JSP中引入标准函数的声明

<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions" %>

下面是JSTL中自带的方法列表以及其描述

 

函数名 函数说明 使用举例
 contains 判断字符串是否包含另外一个字符串 <c:if test="${fn:contains(name, searchString)}">
 containsIgnoreCase 判断字符串是否包含另外一个字符串(大小写无关) <c:if test="${fn:containsIgnoreCase(name, searchString)}">
 endsWith 判断字符串是否以另外字符串结束 <c:if test="${fn:endsWith(filename, ".txt")}">
 escapeXml 把一些字符转成XML表示,例如<字符应该转为< ${fn:escapeXml(param:info)}
 indexOf 子字符串在母字符串中出现的位置 ${fn:indexOf(name, "-")}
 join 将数组中的数据联合成一个新字符串,并使用指定字符格开 ${fn:join(array, ";")}
 length 获取字符串的长度,或者数组的大小 ${fn:length(shoppingCart.products)}
 replace 替换字符串中指定的字符 ${fn:replace(text, "-", "•")}
 split 把字符串按照指定字符切分 ${fn:split(customerNames, ";")}
 startsWith 判断字符串是否以某个子串开始 <c:if test="${fn:startsWith(product.id, "100-")}">
 substring 获取子串 ${fn:substring(zip, 6, -1)}
 substringAfter

获取从某个字符所在位置开始的子串

${fn:substringAfter(zip, "-")}
 substringBefore 获取从开始到某个字符所在位置的子串 ${fn:substringBefore(zip, "-")}
 toLowerCase 转为小写 ${fn.toLowerCase(product.name)}
 toUpperCase 转为大写字符 ${fn.UpperCase(product.name)}
 trim 去除字符串前后的空格 ${fn.trim(name)}

二 : 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截

首先要了解中文字符有多种编码及各种编码的特征。(www.61k.com]

假设n为要截取的字节数。

我是abc 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串,但要保证汉字不被截取半个,如“我ABC”,4,应该截取“我AB”,输入“我ABC汉DEF”,6,应该输出“我ABC”,而不是“我ABC+汉的半个”我是abc 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串,但要保证汉字不被截取半个,如“我ABC”,4,应该截取“我AB”,输入“我ABC汉DEF”,6,应该输出“我ABC”,而不是“我ABC+汉的半个”View Code

public class Test {  /**  * @param args  */  public static void main(String[] args) {  String str = "我a爱中华abc我爱传智def";  int num = 0;  try {  num = trimGBK(str.getBytes("GBK"),6);  } catch (UnsupportedEncodingException e) {  e.printStackTrace();  }  System.out.println(str.substring(0,num) );  }  public static int trimGBK(byte[] buf,int n){  int num = 0;  boolean bChineseFirstHalf = false;  for(int i=0;i<n;i++)  {  if(buf[i]<0 && !bChineseFirstHalf){  bChineseFirstHalf = true;  }else{  num++;  bChineseFirstHalf = false; }  }  return num;  } }

三 : 读取 XML 数据时,超出最大字符串内容长度配额 (8192)

格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://www.thermo.com/informatics/xmlns/limswebservice 进行反序列化时出错: ProcessResponse。[www.61k.com)InnerException 消息是“反序列化对象 属于类型 DAL.ServiceReference1.ProcessResponseBody 时出现错误。读取 XML 数据时,超出最大字符串内容长度配额 (8192)。通过更改在创建 XML 读取器时所使用的 XmlDictionaryReaderQuotas 对象的 MaxStringContentLength 属性,可增加此配额。 行 1,位置 10694。”。有关详细信息,请参见 InnerException。

第一步在服务器配置文件添加添加如下

主要是

maxReceivedMessageSize与maxStringContentLength

<system.serviceModel> 下添加 <bindings> <basicHttpBinding> <binding name="Basicbindings" maxReceivedMessageSize="202400000"> <readerQuotas maxStringContentLength="2024000000"/> </binding> </basicHttpBinding> </bindings>

第二步在客户端生成的配置文件修改

修改

maxReceivedMessageSize,maxBufferSize,maxStringContentLength三个值

<binding name="BasicHttpBinding_TaoQuData" closeTimeout="00:01:00"  openTimeout="00:01:00" receiveTimeout="00:10:00" sendTimeout="00:01:00"  allowCookies="false" bypassProxyOnLocal="false" hostNameComparisonMode="StrongWildcard"  maxBufferSize="2024000000" maxBufferPoolSize="524288" maxReceivedMessageSize="2024000000"  messageEncoding="Text" textEncoding="utf-8" transferMode="Buffered"  useDefaultWebProxy="true">  <readerQuotas maxDepth="32" maxStringContentLength="2024000000" maxArrayLength="16384"  maxBytesPerRead="4096" maxNameTableCharCount="16384" />  <security mode="None">  <transport clientCredentialType="None" proxyCredentialType="None"  realm="" />  <message clientCredentialType="UserName" algorithmSuite="Default" />  </security>  </binding>

四 : Excel函数:截尾取整函数

Excel函数:截尾取整函数

⑴功能
截去指定数位后的有效数字返回数据。(www.61k.com]
⑵格式
TRUNC(数值或数值单元格,指定数位)
⑶示例
A列          B列
1245.251
①截去小数取整数
B1单元格中输入公式
=TRUNC(A1,0)或者=TRUNC(A1),返回值为1245。
②保留1位小数论文联盟 www.61k.com
B1单元格中输入公式
=TRUNC(A1,1)=1245.2
③保留百位数字
B1单元格中输入公式
=TRUNC(A1,-2)=1200
说明:
函数TRUNC对指定的保留数位,右侧数位不进行四舍五入,直接用0替代。

扩展:截尾取整函数 / 将数字截尾取整的函数 / excel截尾函数

本文标题:excel截取字符串函数-jstl 字符串处理函数
本文地址: http://www.61k.com/1153360.html

61阅读| 精彩专题| 最新文章| 热门文章| 苏ICP备13036349号-1