以文本方式查看主题 - Foxtable(狐表) (http://foxtable.net/bbs/index.asp) -- 专家坐堂 (http://foxtable.net/bbs/list.asp?boardid=2) ---- 如何通过过程对某个单元格赋值 (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=188150) |
-- 作者:lesei -- 发布时间:2023/9/4 18:15:00 -- 如何通过过程对某个单元格赋值 想通过过程对表a的某个单元格进行赋值,请问代码怎么写哈? 过程共需要传递三个函数,分别是表名称(比如,表a),行、列。
|
-- 作者:有点蓝 -- 发布时间:2023/9/4 20:02:00 -- 至少需要4个参数,建议使用内部函数:http://www.foxtable.com/webhelp/topics/1486.htm 比如定义函数abc,函数代码为 dim 表名 as string = args(0) dim 行 as integer = args(1)dim 列 as string = args(2) dim 值 as string = args(3)tables(表名).rows(行)(列) = 值 然后按钮调用函数代码为: Functions.Execute("abc","表A",1,2,"我是一个值") \'给表A第2行,第3列的单元格赋值为"我是一个值"
[此贴子已经被作者于2023/9/4 20:32:16编辑过]
|
-- 作者:lesei -- 发布时间:2023/9/4 20:16:00 -- datatable行、列脚标(你上例里的行脚标2,列脚标3)是什么类型的数据?是固定的吗? 为啥问这个问题? 因为,你给的代码,行列脚标都是以数字形式传递的。 我自己写的,列脚标以数字3传递,报错。 附信息:我的表横坐标(行)写的都是数字123456789之类。我表的纵坐标名称都是第一列、第二列这样的名字,我传字符串没报错。
|
-- 作者:有点蓝 -- 发布时间:2023/9/4 20:34:00 -- 针对table 行:http://www.foxtable.com/webhelp/topics/1438.htm针对datatable
|
-- 作者:lesei -- 发布时间:2023/9/4 21:22:00 -- 你的建议是用到了“内部函数”。 在帮助里还有:杂项、高级话题、定义过程(这里定义的过程还是全局的)。 请问: 1.我觉得内部函数也是全局任何地方都可以调用。 那么自定义的内部函数与自定义的过程有什么区别? 我觉得二者区别是: 1.差一个返回值。函数有返回值,过程没有。 2.自定义的内部函数,传参个数可以是任意个。而且每个参数的类型也可以不同。 自定义过程传递的参数类型要提前声明,且传递的参数个数也得提前声明。
[此贴子已经被作者于2023/9/4 21:24:47编辑过]
|
-- 作者:有点蓝 -- 发布时间:2023/9/4 21:24:00 -- 差不多的。就是全局代码每次更改都得重启项目比较麻烦 |
-- 作者:lesei -- 发布时间:2023/9/4 21:33:00 -- 我觉得二者区别是: 1.差一个返回值。函数有返回值,过程没有。 2.自定义的内部函数,传参个数可以是任意个。而且每个参数的类型也可以不同。 自定义过程传递的参数类型要提前声明,且传递的参数个数也得提前声明。 问题: 1.关于二者的区别,我说的对吗? 2.定义全局过程时,怎样定义能使得传递的参数不在意变量类型? |
-- 作者:有点蓝 -- 发布时间:2023/9/4 22:02:00 -- 1、不对。function类型的过程可以有返回值的:http://www.foxtable.com/webhelp/topics/1938.htm 2、Foxtable使用的就是vb.net,所有vb.net的语法都可以使用。动态参数可以百度搜“ParamArray”
|