水晶报表-控制结构-For 循环(Crystal 语法)

For 循环使您能够对一系列表达式多次求值。这不同于 If 和 Select 表达式,在 If 和 Select 语句中,程序在对公式求值时几乎同时传递每个语句。

如果事先知道需要对语句求值的次数,最好使用 For 循环。

使用 For 循环

假设要反转 {客户.客户名} 字符串。例如,将“City Cyclists”变为“stsilcyC ytiC”。

Local StringVar str := "";
Local NumberVar strLen :
=
Length ({Customer.Customer Name});
Local NumberVar i;
For i :
= 1 To strLen Do
(
Local NumberVar charPos :
= strLen - i + 1;
str :
= str + {Customer.Customer Name}[charPos]
);
str

假设字段 {客户.客户名} 当前值为“Clean Air”,检查该公式是如何运行的。将变量 strLen 赋值为“Clean Air”的长度,也就是 9。变量 i 称为 For 计数器变量,因为其值随着 For 循环的每次迭代而更改。换言之,它用于计算循环的迭代次数。For 循环将迭代 9 次。在第一次迭代时,i 是 1,接着是 2,然后是 3,依此类推,直到最后 i = 9。在第一次迭代时,{客户.客户名} 的第九个字符被追加到空字符串变量 str 中。这样,在第一次迭代后 str 等于“r”。在第二次迭代时,{客户.客户名} 的第八个字符追加到 str 上,因此 str 等于“ri”。程序继续迭代,直到第九次迭代后 str 等于“riA naelC”,即反转字符串。

使用 For 循环和 Step 子句

下面是上述公式的更简单的演示,它使用具有负 Step 值 (-1) 的 Step 子句。对于“Clean Air”示例,在第一次迭代时 i 是 9,第二次迭代时 i 是 8,第三次迭代时 i 是 7,依此类推,直到最后一次迭代时 i 是 1。

Local StringVar str := "";
Local NumberVar strLen :
=
Length ({Customer.Customer Name});
Local NumberVar i;
For i :
= strLen To 1 Step -1 Do
(
str :
= str + {Customer.Customer Name}[i]
);
str
使用 StrReverse

最简单的方法是使用内置函数 StrReverse:

StrReverse ({Customer.Customer Name})
在 Crystal Reports 中,内置的字符串函数可以处理许多字符串处理应用,而这些应用通常要使用 For 循环或其他类型的循环进行处理。但是,在处理字符串和数组方面,For 循环能提供最灵活和最强大的功能。如果内置函数不适用于所需的应用程序,则该循环可能必不可少。

转载于:https://www.cnblogs.com/fannywu/archive/2011/04/14/2016203.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/475667.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 57. 插入区间(一次遍历)

1. 题目 给出一个无重叠的 ,按照区间起始端点排序的区间列表。 在列表中插入一个新的区间,你需要确保列表中的区间仍然有序且不重叠(如果有必要的话,可以合并区间)。 示例 1: 输入: intervals [[1,3],[6,9]], newI…

Windows下usb接口驱动技术(一)

Windows下usb接口芯片的驱动技术一、 USB概述 USB的英文全称为Universal Serial Bus,中文含义是通用串行总线,是由Conpaq、DEC、IBM、Inter、Microsoft、NEC和Northen Telecom等公司为简化PC与外设之间的互连而共同研究开发的一种免费的标准化连接器&#x…

LeetCode 363. 矩形区域不超过 K 的最大数值和(DP+set二分查找)

1. 题目 给定一个非空二维矩阵 matrix 和一个整数 k,找到这个矩阵内部不大于 k 的最大矩形和。 示例: 输入: matrix [[1,0,1],[0,-2,3]], k 2 输出: 2 解释: 矩形区域 [[0, 1], [-2, 3]] 的数值和是 2, 且 2 是不超过 k 的最大数字(k 2…

实体框架的惨痛教训

个人评价:通过半年的开发,项目已经运营.但回想起来,整个项目中遇到了许多的问题,还好需求策划上一直很好(原因在于老板原来就是一个产品总监且目前的策划都很有逻辑性),所以对于开发人员而言没有吃苦.问题在于微软的实体框架EF让人简直痛恨至极(个人愚见),让我们浪费了大量时间…

LeetCode 第 27 场双周赛(1125/1966,前57.2%)

文章目录1. 比赛结果2. 题目1. LeetCode 5408. 通过翻转子数组使两个数组相等 easy2. LeetCode 5409. 检查一个字符串是否包含所有长度为 K 的二进制子串 medium3. LeetCode 5410. 课程安排 IV medium (Floyd-Warshall)4. LeetCode 5411. 摘樱桃 II hard…

LeetCode 1464. 数组中两元素的最大乘积

1. 题目 给你一个整数数组 nums,请你选择数组的两个不同下标 i 和 j,使 (nums[i]-1)*(nums[j]-1) 取得最大值。 请你计算并返回该式的最大值。 示例 1: 输入:nums [3,4,5,2] 输出:12 解释:如果选择下标…

修改mysql文件的存储路径

使用本地数据库时,常常会发生磁盘爆满变红的情况,特别是C盘,这时候我们希望将mysql本地数据库存储的文件移动到D盘或者E盘,下面是手动调整的办法:1.关闭mysql服务; 左下角开始处输入“服务”,回…

Dynamic programming solving ULS

转载于:https://www.cnblogs.com/elitez/archive/2011/04/21/2024095.html

Excel里,vlookup函数各种应用-匹配多列、多条件匹配

1.vlookup函数常规应用:一个条件匹一列数据; 示例公式:VLOOKUP(A2,test!$A$2:$B$53,2,0) 其中:A2是目标表的匹配条件(学号);test!$A$2:$B$53是被匹配表的数据列;2是指被匹配数据列…

mysql提取各种数据时间的各种方法

1.提取数据的年月日(eg:2018-06-21)方法1:SUBSTR(time FROM 1 FOR 10);方法2:DATE(time);方法3:DATE_FORMAT(time,%Y-%m-%…

LeetCode 1466. 重新规划路线(DFS/BFS)

文章目录1. 题目2. 解题2.1 DFS2.2 BFS1. 题目 n 座城市,从 0 到 n-1 编号,其间共有 n-1 条路线。因此,要想在两座不同城市之间旅行只有唯一一条路线可供选择(路线网形成一颗树)。 去年,交通运输部决定重新…

解决The total number of locks exceeds the lock table size错误

mysql在进行大批量的数据操作时,会报“The total number of locks exceeds the lock table size”,特别是执行create、update语句的时候, 在出现错误的那段查询语句之前写上这么一句话: show variables like "%_buffer%"…

MySQL 基本查询、条件查询、投影查询

文章目录1. 基本查询2. 条件查询3. 投影查询练习 LeetCode 595. 大的国家练习 LeetCode 584. 寻找用户推荐人练习 LeetCode 1173. 即时食物配送 I练习 LeetCode 610. 判断三角形学习自 廖雪峰的官方网站 1. 基本查询 SELECT * FROM <表名>*表示所有内容 许多检测工具…

开始android旅程

这算是我第一个技术类的博客了&#xff0c;因为小女不才&#xff0c;很多东西都得需要学习&#xff0c;最近发表的一些日志可能是转载或者部分转载&#xff0c;但是我会努力认真的写我的学习心得的&#xff5e;&#xff5e; 这也算是我程序员成长的记录吧&#xff5e;转载于:ht…

解决mysql导出scv文件乱码、蹿行的问题

工作原因&#xff0c;常常不能实现完全的线上化&#xff08;即&#xff0c;所有数据都在线上完成&#xff0c;不需要导入导出&#xff09;&#xff0c;而导出Excel常常比修炼成仙还慢&#xff0c;因此&#xff0c;我们将数据库文件导出到本地使用的时候&#xff0c;常常使用的方…

MySQL 排序、分页查询、聚合查询

文章目录1. 排序2. 分页查询3. 聚合查询3.1 分组聚合 GROUP BY练习 LeetCode 176. 第二高的薪水练习 LeetCode 177. 第N高的薪水练习 LeetCode 182. 查找重复的电子邮箱练习 LeetCode 620. 有趣的电影练习 LeetCode 183. 从不订购的客户练习 LeetCode 596. 超过5名学生的课练习…

1799

/* 简单的数学几何题 */// include file #include <cstdio> #include <cstdlib> #include <cstring> #include <cmath> #include <cctype> #include <ctime>#include <iostream> #include <sstream> #include <fstream>…

解决mysql导数据时,格式不对、导入慢、丢数据的问题

如果希望一劳永逸的解决慢的问题&#xff0c;不妨把你的mysql升级到mysql8.0吧&#xff0c;mysql8.0默认的字符集已经从latin1改为utf8mb4&#xff0c;因此现在UTF8的速度要快得多&#xff0c;在特定查询时速度提高了1800&#xff05;&#xff01; mysql8.0 安装教程但是如果时…

MySQL 多表查询、连接查询(内连接、外连接)

文章目录1. 多表查询2. 连接查询练习 LeetCode 175. 组合两个表练习 LeetCode 181. 超过经理收入的员工练习 LeetCode 1378. 使用唯一标识码替换员工ID练习 LeetCode 1068. 产品销售分析 I练习 LeetCode 1069. 产品销售分析 II练习 LeetCode 1303. 求团队人数练习 LeetCode 135…

屏蔽非法路由,好好上网!

学校有人用路由&#xff0c;我人品差&#xff0c;经常受到路由器干扰&#xff0c;不能上网。本机IP应为172.16.*.*&#xff0c;被换成了192.168.*.*&#xff0c;不能连接上网认证服务器&#xff0c;及其郁闷。 开学闲暇之余&#xff0c;探索了多种方法&#xff0c;下面总结一下…