一 : 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为要截取的字节数。
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 字符串处理函数61阅读| 精彩专题| 最新文章| 热门文章| 苏ICP备13036349号-1