当前位置: 首页 > 编程日记 > 正文

c语言向表格内存入数据,怎么实现横向到存入多个单元格,在列数固定的报表中逐格横向填充数据并折行...

在很多需要打印的报表中,受限于纸张的大小,往往会限制行数或者固定列数。我们在《单据类报表的制作》一文中,曾经介绍了限制了行数的情况如何实现,现在,我们再来看一下,在固定了列数的情况下,如果在某些行中,逐格横向填充数据,并在超过列数后自动折行。

我们先看一个例子的效果图:

5d132990c38f71665153d7203bf42487.png

在这张报表,由上而下其实分成了几个部分:

首先,表头和前两行是简单的描述信息;

然后,实际上是一个 4 行 5 列的固定表格,对“核定”、“实有”、“超空”、“批准使用”这四个项目进行了统计汇总;

再往下, “登记”这一行填充了来自数据库的人员姓名,为了整齐美观,要求按 4 个项目对应的 4 列逐格填充,而且人员数量会根据数据库中的实际情况填充,如果,当多于 4 人时还需要折行后继续按照一行 4 列进行填充,如图中的蓝色字体部分所示;

最后的两行都是文本描述。

类似的表格其实我们常常会遇到,例如下面这张 “学校公物监护人统计表”:

636fcafba0182de0c61fe1dfb0e02a48.png

每一类公物的监护人横向逐格填写,超过 4 个时,都要折行展现,比如表中的“窗帘、窗户”的监护人。

熟悉报表设计的兄弟姐妹都清楚,一个业务字段的取值一般都是定义到一个格子后自动扩展,现在要分别放到 4 个单元格,这怎么拆开定义?

别着急!!下面将结合第一个“使用单”的例子,来了解一个神奇的报表工具。

根据表格本身硬性要求(4 列是固定列,不能自动扩展),我们能想到的方法只有用坐标的方式,按照位置号把登记人依次摆到对应单元格。

如果数据库中登记人员的姓名(XM)如下

ab68d84d50ef4a2709c1c7a93560926f.png

那么我们就把登记人前 4 个(张三、李四、王二、王麻子)依次放到对应 14 格子里,下面 4 个再按照 58 放至第二行,依次类推。。。

至于另一个问题是应该摆几行?其实很简单,总人数除以 4,我们就可以判断出来了。

下面就是具体的操作过程:

把“使用单”固定格式的部分先画出来……

设置数据集,例子里使用润乾报表内建数据集进行模拟,如上图所示;

按照上面的分析思路完成行数计算及按坐标摆放的工作

2f52d2209db2062cf1e3b23143d52616.png

其中:

(1)在“登记”行前增加一行,在 B11 中定义表达式:ds2.select(XM), 把登记人(XM)数据查出来备用,同时 B11 设置为“不可扩展”,此时为 XM 字段所有数据以逗号隔开的字符串(如,“张三, 李四”)。

(2)计算行数

在原 D 列前插入一列,在 D12 中定义表达式:

=to(1,int(ceil(ds2.count()/4)))

其中,int(ceil(ds2.count()/4)) 就是可扩展出的总行数

(3)按坐标摆放:

E12 表达式:=split(B11,“,”)(4∗(D12−1)+1)

G12 表达式:=split(B11,“,”)(4∗(D12−1)+2)

I12 表达式:=split(B11,“,”)(4∗(D12−1)+3)

K12 表达式:=split(B11,“,”)(4∗(D12−1)+4)

其中标红的部分即为按位置坐标取数。

(4)把新增的 D 列及 11 行设置为“隐藏”,仅用来辅助存放登记人序列串与生成行数,不需要显示。

4. 最后效果如我所愿,完美解决!

相关文章:

设计模式之简单工厂模式

一、概述 工厂模式具体包括了简单工厂、工厂方法、抽象工厂,它们是按照从简单到复杂的顺序排列的,属于设计模式中的创建型,其中简单工厂并不属于GOF的23中模式。 但是它是理解其它的工厂模式的一个很好的基础,所以很多人在讲述设…

zendserver的版本是怎么回事?免费版哪里去了?

zend server 的版本,官网上说是四个版本,免费版、小企业版、专业版、企业版。 但下载只有一个版本。在下载的页面中大大的free download 很是显眼。安装完成之后显示为企业版。使用几天之后,显示你的许可即将到期。 输入密码,登录…

sql-case when 条件1 then 取值1 when 条件2 then 取值2 else 取值3 end

遇到 XXX情况 就 XXX 遇不到就 XXX 结束case when …… then …… else …… end 例如一个3条件取值的字段: case when 条件1 then 取值1 when 条件2 then 取值2 else 取值3 end when后接条件语句,then后为字段取值(数值或字符串等都可以&…

二叉树:二叉搜索树的创建和插入

二叉搜索树又名二叉排序树。 大概简略的思维导图如下,方便记忆特性 基本二叉搜索树创建过程如下 /*数据结构如下*/ typedef struct tree {int data;struct tree *left NULL;struct tree *right NULL; }Tree,*TreeNode;/*Node 为二叉树根节点,insert…

ie7和ie8 select使用jquery clone不兼容处理

本文解决方案基于http://blog.csdn.net/zzx3q/article/details/8017794 在ie7和ie8下&#xff0c;用jquery clone复制一个select&#xff0c;复制的select是本体的select初始化时的一个副本&#xff0c;无法复制目前本体select选择。 解决方案&#xff1a; <!DOCTYPE html&g…

c语言中floox的头文件,PC-1211袖珍计算机在合成氨厂生产中的应用 第五讲 循环语句(FOR-NEXT语句)...

PC-1211袖珍计算机在合成氨厂生产中的应用 第五讲 循环语句(FOR-NEXT语句)在化工生产中为了分析两个或两个以上参数对生产的影响往往需要进行某些有规律的重复计算。这些计算在程序中可以用赋值语句或条件语句来实现,但从下面的介绍可以看出,这时若采用循(本文共7页)阅读全文&g…

C#Winform+WindowsAPI做个剪贴板无缝自动保存器(视频截图利器)

C#WinformWindowsAPI做个剪贴板无缝自动保存器&#xff08;视频截图利器&#xff09; (本文最新代码已上传到GitHub&#xff0c;地址在&#xff08;https://github.com/bitzhuwei/ClipboardImageSaver&#xff09;) 利用C#和Window API做了个自动保存剪贴板内的图片的工具&…

Kafka配置SASL/PLAIN认证

1、安装zk&#xff0c;kafka 2、配置server.properties security.inter.broker.protocolSASL_PLAINTEXT sasl.mechanism.inter.broker.protocolPLAIN sasl.enabled.mechanismsPLAIN listenersSASL_PLAINTEXT://0.0.0.0:9092 advertised.listenersSASL_PLAINTEXT://host:9092 3…

二叉树:二叉搜索树的编码和解码

二叉搜索树的编码和解码描述&#xff1a; 编码&#xff1a;即将一个二叉搜索树编码&#xff0c;节点数值转换为字符串 解码&#xff1a;即将一个字符串解码&#xff0c;数值转换为对应的二叉搜索树的节点 过程导图如下&#xff1a; 针对性编码实现如下: /*数字转字符串*/ vo…

springmvc3.2+spring+hibernate4全注解方式整合(一)

<?xml version"1.0" encoding"UTF-8"?> <web-app xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xmlns"http://java.sun.com/xml/ns/javaee" xmlns:web"http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd&…

c 应用程序多语言版本,c – 在win32 API应用程序中实现全球化/多语言功能

Windows上多语言应用程序的基础是使用“资源”.资源是附加在可执行文件末尾的块,它只包含数据,并以非常特定的方式格式化,以便Windows能够解释这些数据.在资源中,您可以找到对话框,字符串表以及版本信息(在资源管理器中文件的属性对话框中显示的信息).您可以通过在Visual C中打…

整数展示分数和整形数的四则运算

文章结束给大家来个序程员笑话&#xff1a;[M] /* * Copyright (c) 2013, 烟台大学计算机学院 * All rights reserved. * 文件名称&#xff1a;test.cpp * 作者&#xff1a;邱学伟 * 成完日期&#xff1a;2013 年 5 月 4 日 * 版本号&#xff1a;v1.0 * 输入描述&#xff1a;无…

二叉树:二叉搜索树实现 逆序数问题

关于逆序数的问题描述如下&#xff1a; 已知数组nums&#xff0c;求新数组count&#xff0c;count[i]代表了在nums[i]右侧且比 nums[i]小的元素个数。 例如: nums [5, 2, 6, 1], count [2, 1, 1, 0]; nums [6, 6, 6, 1, 1, 1], count [3, 3, 3, 0, 0, 0]; nums [5, -7, 9…

C语言文件实验要求,实验教学的目的和要求.doc

实验教学的目的和要求实验教学的目的和要求&#xff1a;通过实验&#xff0c;让学生全面掌握高级语言程序设计的思想与方法&#xff0c;掌握C语言的特点&#xff0c;C语言的语法规则&#xff0c;C语言的数据类型、表达式及控制流程&#xff1b;通过编程&#xff0c;提高程序设计…

这些工作的日子

已经毕业10个月了&#xff0c;工作了9个月&#xff0c;想说我是个刚毕业的大学僧&#xff0c;没有遇到什么社会上的勾心斗角&#xff0c;没有遇到天大的难题&#xff0c;没有看到那种大起大落的景象&#xff0c;一切还是那样平平淡淡的&#xff0c;当看见附近大学的大学僧的时候…

python基础类型

range&#xff1a;生成指定范围内的数字&#xff0c;只在python2中使用&#xff0c;python3中没有此用法 例&#xff1a;生成0-30内的偶数 转载于:https://www.cnblogs.com/gaoyuxia/p/10239421.html

linux系统目录树/内核源码目录树

关于系统目录树和源码目录树的结构图如下 内核版本: centos 7.0 升级内核之后 3.10.0-957-5.1.e17

顺时针打印二维数组C语言递归,按顺时针打印矩阵

存在二种解题思路: 一种是递归解法,一种是层层递进解法图解递归解法如图所示, 一个5*5的矩阵先打印最外层的圈, 然后剩余最里层3*3的矩阵, 如图.将3*3的矩阵继续打印最外层,思路与打印最外层思路一样,我们就可以考虑使用递归实现.最后只剩余一个元素,也可以看成一个矩阵,不过不…

降低噪声和电磁干扰的原则

1.尽量采用45折线转载于:https://www.cnblogs.com/asulove/p/3827246.html

翻译:java.util.regex.Pattern

java.util.regex.PatternA compiled representation of a regular expression. A regular expression&#xff08;正则表达式&#xff09;, specified as a string, must first be compiled into an instance of this class&#xff08;首先编译成Pattern对象&#xff09;. The…

学习笔记53—Wilcoxon检验和Mann-whitney检验的区别

Wilcoxon signed-rank test应用于两个related samples Mann–Whitney U test也叫Wilcoxon rank-sum test&#xff0c;应用于两个independent samples的情samples size小的时候&#xff0c;是有列表的&#xff0c;sample size大到20左右时&#xff0c;就可以使用正态分布来近似…

s-systemtap工具使用图谱(持续更新)

整体的学习思维导图如下&#xff0c;后续持续更新完善 文章目录安装简介执行流程执行方式stap脚本语法探针语法API函数探针举例变量使用基本应用1. 定位函数位置2. 查看文件能够添加探针的位置3. 打印函数参数&#xff08;结构体&#xff09;4. 打印函数局部变量5. 修改函数局…

2014 Super Training #8 C An Easy Game --DP

原题&#xff1a;ZOJ 3791 http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode3791 题意&#xff1a;给定两个0-1序列s1, s2&#xff0c;操作t次&#xff0c;每次改变m个位置&#xff0c;求把s1改变为s2的方法总数。解法&#xff1a; DP&#xff0c;s1和s2哪些位置…

qq分享组件 android,移动端,分享插件

移动端&#xff0c;分享插件发布时间&#xff1a;2018-06-26 10:03,浏览次数&#xff1a;762最近有一个活动页需要在移动端浏览器分享网页到微信&#xff0c;QQ。虽然每一个浏览器都有分享到微信的能力&#xff0c;但不是每个都提供接口供网页来调用。及时有提供&#xff0c;浏…

MySQL中更改表操作

2019独角兽企业重金招聘Python工程师标准>>> 添加一列&#xff1a; alter table t_stu add tel char(20); 删除一个列&#xff1a; alter table t_stu drop column tel; 添加唯一约束&#xff1a; alter table t_stu add constraint uk_srname unique(scode); 添加主…

Maven-环境配置

二更 可算搞好了&#xff0c;除了下面外&#xff0c;我找到了setting.xml里面的东西&#xff0c;给出来就好了&#xff0c;简单就是mvn -v弄好后&#xff0c;setting.xml里面写好的话&#xff0c;直接加入&#xff0c;然后让eclipse下载jar包 然后就可以运行网上的基本项目了 1…

分布式存储(ceph)技能图谱(持续更新)

一下为个人结合其他人对分布式存储 所需的技能进行总结&#xff0c;绘制成如下图谱&#xff0c;方便针对性学习。 这里对分布式存储系统接触较多的是ceph,所以在分布式存储系统分支上偏向ceph的学习。 如有分类有问题或者分支不合理&#xff0c;欢迎大家批评指正&#xff0c;目…

android如何查看方法属于哪个类,Android Studio查看类中所有方法和属性

css-关于位置当你设置一个你想要相对的模块为relative 你这个模块为absolute 则你的这个absolute会相对relative的那个模块进行移动.微信公众平台自动回复wechatlib&period;jar的生成及wechatlib解析微信公众平台出来有一段时日了,官方提供的自动回复的接口调用大致是这么些…

读javascript高级程序设计03-函数表达式、闭包、私有变量

一、函数声明和函数表达式 定义函数有两种方式&#xff1a;函数声明和函数表达式。它们之间一个重要的区别是函数提升。 1.函数声明会进行函数提升&#xff0c;所以函数调用在函数声明之前也不会报错&#xff1a; test(); function test(){ alert(1); } 2.函数表达式不会进行函…

集成公司内部的多个子系统(兼容B/S和C/S),实现单点登录功能的多系统的统一入口功能...

有一句话也挺有意思的&#xff0c;一直在模仿但从未超越过&#xff0c;文章里的技术也都是相对简单的技术&#xff0c;但是实实在在能解决问题&#xff0c;提高效率。现在人都懒得瞎折腾&#xff0c;能多简单就多简单&#xff0c;谁都不希望总是做一些重复的工作&#xff0c;我…