`
刘金剑
  • 浏览: 147889 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ETL字符串长度判断并截取

etl 
阅读更多
${fn:substring(wjcd.lrsj, 0, 16)}

使用functions函数来获取list的长度

${fn:length(list)}


<c:if test="${fn:length(character) > 19 }">
</c:if>

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



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

函数描述

fn:contains(string, substring) 如果参数string中包含参数substring,返回true
fn:containsIgnoreCase(string, substring) 如果参数string中包含参数substring(忽略大小写),返回true
fn:endsWith(string, suffix) 如果参数 string 以参数suffix结尾,返回true
fn:escapeXml(string) 将有特殊意义的XML (和HTML)转换为对应的XML character entity code,并返回
fn:indexOf(string, substring) 返回参数substring在参数string中第一次出现的位置
fn:join(array, separator) 将一个给定的数组array用给定的间隔符separator串在一起,组成一个新的字符串并返回。
fn:length(item) 返回参数item中包含元素的数量。参数Item类型是数组、collection或者String。如果是String类型,返回值是String中的字符数。
fn:replace(string, before, after) 返回一个String对象。用参数after字符串替换参数string中所有出现参数before字符串的地方,并返回替换后的结果
fn:split(string, separator) 返回一个数组,以参数separator 为分割符分割参数string,分割后的每一部分就是数组的一个元素
fn:startsWith(string, prefix) 如果参数string以参数prefix开头,返回true
fn:substring(string, begin, end) 返回参数string部分字符串, 从参数begin开始到参数end位置,包括end位置的字符
fn:substringAfter(string, substring) 返回参数substring在参数string中后面的那一部分字符串
fn:substringBefore(string, substring) 返回参数substring在参数string中前面的那一部分字符串
fn:toLowerCase(string) 将参数string所有的字符变为小写,并将其返回
fn:toUpperCase(string) 将参数string所有的字符变为大写,并将其返回
fn:trim(string) 去除参数string 首尾的空格,并将其返回


二、JSP EL简介
1、语法结构 ${expression} 2、[ ]与.运算符 EL 提供“.“和“[ ]“两种运算符来存取数据。 当要存取的属性名称中包含一些特殊字符,如.或?等并非字母或数字的符号,就一定要使用“[ ]“。例如: ${user.My-Name}应当改为${user["My-Name"] } 如果要动态取值时,就可以用“[ ]“来做,而“.“无法做到动态取值。例如: ${sessionScope.user[data]}中data 是一个变量 3、变量 EL存取变量数据的方法很简单,例如:${username}。它的意思是取出某一范围中名称为username的变量。 因为我们并没有指定哪一个范围的username,所以它会依序从Page、Request、Session、Application范围查找。 假如途中找到username,就直接回传,不再继续找下去,但是假如全部的范围都没有找到时,就回传null。 属性范围在EL中的名称 Page PageScope Request RequestScope Session SessionScope Application ApplicationScope

二、JSP EL 中的有效表达式
  有效表达式可以包含文字、操作符、变量(对象引用)和函数调用。我们将分别了解这些有效表达式中的每一种:

1、文字 
JSP 表达式语言定义可在表达式中使用的以下文字: 


文字 文字的值 
Boolean
true 和 false

Integer
与 Java 类似。可以包含任何正数或负数,例如 24、-45、567

Floating Point
与 Java 类似。可以包含任何正的或负的浮点数,例如 -1.8E-45、4.567

String
任何由单引号或双引号限定的字符串。对于单引号、双引号和反斜杠,使用反斜杠字符作为转义序列。必须注意,如果在字符串两端使用双引号,则单引号不需要转义。

Null null 


2、操作符
JSP 表达式语言提供以下操作符,其中大部分是 Java 中常用的操作符:


术语 定义 
算术型
+、-(二元)、*、/、div、%、mod、-(一元)

逻辑型
and、&&、or、||、!、not

关系型
==、eq、!=、ne、、gt、<=、le、>=、ge。可以与其他值进行比较,或与布尔型、字符串型、整型或浮点型文字进行比较。


空操作符是前缀操作,可用于确定值是否为空。

条件型 A ?B :C。根据 A 赋值的结果来赋值 B 或 C。  


3、隐式对象
JSP 表达式语言定义了一组隐式对象,其中许多对象在 JSP scriplet 和表达式中可用:

术语 定义 
pageContext
JSP 页的上下文。它可以用于访问 JSP 隐式对象,如请求、响应、会话、输出、servletContext 等。例如,${pageContext.response} 为页面的响应对象赋值。



此外,还提供几个隐式对象,允许对以下对象进行简易访问: 


术语 定义 
param
将请求参数名称映射到单个字符串参数值(通过调用 ServletRequest.getParameter (String name) 获得)。getParameter (String) 方法返回带有特定名称的参数。表达式 $(param.name) 相当于 request.getParameter (name)。

paramValues
将请求参数名称映射到一个数值数组(通过调用 ServletRequest.getParameter (String name) 获得)。它与 param 隐式对象非常类似,但它检索一个字符串数组而不是单个值。表达式 ${paramvalues.name) 相当于 request.getParamterValues(name)。

header
将请求头名称映射到单个字符串头值(通过调用 ServletRequest.getHeader(String name) 获得)。表达式 ${header.name} 相当于 request.getHeader(name)。

headerValues
将请求头名称映射到一个数值数组(通过调用 ServletRequest.getHeaders(String) 获得)。它与头隐式对象非常类似。表达式 ${headerValues.name} 相当于 request.getHeaderValues(name)。

cookie 将 cookie 名称映射到单个 cookie 对象。向服务器发出的客户端请求可以获得一个或多个 cookie。表达式 ${cookie.name.value} 返回带有特定名称的第一个 cookie 值。如果请求包含多个同名的 cookie,则应该使用 ${headerValues.name} 表达式。 
initParam 将上下文初始化参数名称映射到单个值(通过调用 ServletContext.getInitparameter(String name) 获得)。  


除了上述两种类型的隐式对象之外,还有些对象允许访问多种范围的变量,如 Web 上下文、会话、请求、页面:


术语 定义 
pageScope
将页面范围的变量名称映射到其值。例如,EL 表达式可以使用 ${pageScope.objectName} 访问一个 JSP 中页面范围的对象,还可以使用 ${pageScope.objectName.attributeName} 访问对象的属性。

requestScope
将请求范围的变量名称映射到其值。该对象允许访问请求对象的属性。例如,EL 表达式可以使用 ${requestScope.objectName} 访问一个 JSP 请求范围的对象,还可以使用 ${requestScope.objectName.attributeName} 访问对象的属性。

sessionScope
将会话范围的变量名称映射到其值。该对象允许访问会话对象的属性。例如:

$sessionScope.name} 

applicationScope
将应用程序范围的变量名称映射到其值。该隐式对象允许访问应用程序范围的对象。



三、特别强调:
1、注意当表达式根据名称引用这些对象之一时,返回的是相应的对象而不是相应的属性。例如:即使现有的 pageContext 属性包含某些其他值,${pageContext} 也返回 PageContext 对象。 

2、 注意 <%@ page isELIgnored="true" %> 表示是否禁用EL语言,TRUE表示禁止.FALSE表示不禁止.JSP2.0中默认的启用EL语言


原文转发连接:http://namas.iteye.com/blog/1623385
分享到:
评论

相关推荐

    去除数据中字符串的换行符;解决ETL中字符串换行符;ORACLE|DB2

    - - 去除数据文件中字符串的换行符; - - 使用此工具,必须有明确的行分隔符标记,且换行符标记不可在字符串中出现。否则无法使用,需要修改匹配搜索方式 ### 工具效率: 亲测200M文件5s中完成转换。 ### 使用...

    各种数据库连接字符串

    与 Informatica(一种流行的 ETL 工具)连接时,其连接字符串通常采用以下格式: ``` Database: oracle.world Connection String Example (TNS Names Entry): TNS_ADMIN=;SID=world;DESCRIPTION=(ADDRESS=(PROTOCOL...

    字符串时间转换时间格式问题带配图完整解决方案--kettle版.doc

    ### 字符串时间转换时间格式问题带配图完整解决方案—Kettle版 #### ETL概念与Kettle简介 ETL(Extract-Transform-Load)即数据抽取、转换、装载的过程,是金融IT领域中处理大数据量的核心技术之一。随着业务的...

    大数据分析技术 BI商业智能分析培训 久其ETL数据集成工具 ETL培训教程资料 第5节 公式体系和服务器端 共15页.pptx

    运算符支持多种操作,如字符串拼接(+)、赋值(=)、条件判断(IF THEN ELSE)以及类似SQL的like操作。函数则提供了更复杂的操作,如Round用于四舍五入,Rand生成随机数,FormatNum处理Excel样式的数字字符串,Add...

    《ETL数据整合与处理(Kettle)》教学教案 —03记录处理.pdf

    7. **字符串操作**:包括各种字符串处理功能,如截取、拼接、查找替换等,用于处理和转换字符串数据。 8. **分组**:通过分组,可以计算每个组的统计信息,如求和、平均值等,这对于聚合和汇总数据非常有用。 在...

    ETL实验3-记录处理

    Kettle提供了多种字符串操作步骤,如"字符串操作",它可以执行诸如去除前导/尾部空白、截取子字符串、拼接字符串等操作。在这个实验中,籍贯字段的空格被去除了,使得后续处理更加方便。 5. **排序记录**: "排序...

    ETL工具,开源,使用需要配置

    1. **QBYJ_ETL.vshost.exe.config** 和 **QBYJ_ETL.exe.config**:这是两个配置文件,可能包含了关于ETL工具的执行环境设置,如连接字符串、日志配置、性能监控等信息。修改这些配置可以调整工具的行为。 2. **emp....

    传统数据仓库ETL设计报告

    ETL平台分为三个主要模块:ETL元数据驱动模块负责根据配置信息生成ETL作业,ETL调度模块配置调度并结合数据质量校验控制执行,而ETL元数据管理模块则用于管理和检索ETL配置信息。 2.1.2.2 ETL平台技术架构 技术...

    ETL Automation使用手册

    ETL Automation 使用手册 ETL Automation 是一个自动化的数据集成工具,旨在帮助用户快速高效地完成数据提取、转换和加载(ETL)过程。本手册将详细介绍 ETL Automation 的安装、配置、使用和管理。 ETL ...

    etl-kettle讲稿

    2. 规范化数据格式:确保数据符合特定格式,例如日期、数字和字符串的转换。 3. 拆分数据:根据业务需求将字段分解,如电话号码的区号和本地号码分离。 4. 验证数据正确性:通过查找和拆分功能检查数据的准确性,...

    ETL系列专题2 ETL数据结构

    Staging数据不仅为ETL系统提供了可靠性保障,还能帮助模块化分析,简化ETL开发的复杂度,并提升ETL团队协同开发的效率。每个步骤的Staging数据结构定义完成后,各个步骤的开发工作可以并行开展。 关于是否采用...

    基于Hadoop的ETL处理Shell架构5

    例如,使用Awk进行数据筛选,Sed进行字符串替换,Cut进行字段截取。 4. **加载(Load):** 转换后的数据需要被加载到目标系统,如Hadoop的HDFS或者HBase这样的NoSQL数据库。使用`hadoop fs -put`命令可将数据写入...

    Java分布式ETL框架

    Java分布式ETL(Extract, Transform, Load)框架是用于大...文件"master_org_source_to_pre"可能表示主数据源到预处理阶段的转换流程,这在ETL过程中是一个常见的步骤,涉及从原始数据源抽取数据并进行初步清洗和转换。

    《ETL数据整合和处理》教学大纲.pdf

    学生将学习到各种数据预处理技术,例如数据排序、去重、替换NULL值、过滤、值映射、字符串操作和分组等。这些操作有助于清洗数据,为后续的数据分析和数据仓库的加载做准备。 在字段处理部分,课程将指导学生如何...

    ETL Automation 使用手册 Version 2.6.0 中文

    ETL Automation 使用手册 Version 2.6.0 中文 ETL Automation 是一个数据集成平台,旨在提供一个自动化的数据集成解决方案。下面是对 ETL Automation 使用手册 Version 2.6.0 中文的详细知识点解释。 ETL ...

    基于Oracle的简单ETL框架

    例如,可以使用COALESCE处理NULL值,REGEXP_REPLACE进行字符串替换,或是通过CASE语句实现条件逻辑。 3. **加载(Load)**:数据转换后,需要将其加载到目标系统,如数据仓库。Oracle支持直接插入(INSERT)、批量...

    kettle常见控件(输入、输出,字段选择、设置变量、记录集连接、值映射、字符串替换、js、Java)的使用案例

    在IT领域,Kettle(又称Pentaho Data Integration或PDI)是一款强大的ETL(Extract, Transform, Load)工具,广泛用于数据集成、数据清洗、数据转换和数据加载任务。本教程将深入探讨Kettle中的一些关键控件,以及...

    ETL规范.doc

    ETL 规范设计指南 ETL(Extract、Transform、Load)是数据集成的重要步骤,涉及到数据的抽取、转换和加载。为了确保 ETL 过程的高效性和可靠性,需要制定相应的规范和标准。本文档旨在提供一份完整的 ETL 规范设计...

    ETL工具信息整理

    - **转换步骤**:Kettle 提供了诸如输入步骤(如表输入、文本文件输入)、转换步骤(如字段选择、字符串操作、日期处理)和输出步骤(如表输出、文本文件输出)等多种类型的步骤。 - **调试和优化**:Kettle 内置了...

Global site tag (gtag.js) - Google Analytics