好吧,我知道这是一个非常小众的问题,但我希望这个过程足够直接……
我的任务是根据客户/订单信息创建数据文件。问题是,数据文件有5个产品的最大限制。
基本上,我得到我的数据,按cust_id分组,创建文件结构,在该循环中,按product_id分组,用新产品信息重写以前file_struct中的字段。这一切都运行得很好,直到用户超过了最大值。
一个简单的例子..
orderArray = arranyew(2);
set order = 1;
loop over cust_id;
field[order][1] = "field(1)"; // cust_id
field[order][2] = "field(2)"; // name
field[order][3] = "field(3)"; // phone
field[order][4] = ""; // product_1
field[order][5] = ""; // quantity_1
field[order][6] = ""; // product_2
field[order][7] = ""; // quantity_2
field[order][8] = ""; // product_3
field[order][9] = ""; // quantity_3
field[order][10] = ""; // product_4
field[order][11] = ""; // quantity_4
field[order][12] = ""; // product_5
field[order][13] = ""; // quantity_5
field[order][14] = "field(4)"; // trx_id
field[order][15] = "field(5)"; // total_cost
counter = 0;
loop over product_id
field[order[4+counter] = productCode;
field[order[5+counter] = quantity;
counter = counter + 2;
end inner loop;
order = order + 1;
end outer loop;就像我说的,在我有一个用户订购了5个以上的产品之前,这个方法工作得很好。
我基本上想要做的是检查每个用户的产品数量,如果这个数字大于5,在文本字段中开始一个新行,但我不知道如何到达那里。
我已经尝试了许多修复,但没有一个能给出我需要的结果。
发布于 2010-11-30 07:52:02
您需要将页眉和页脚字段的插入移动到产品循环中,例如。custid和trx_id字段。
这里有一个粗略的想法,为什么你可以基于你提供的伪代码来做这件事。我相信你可以用更优雅的方式来编写代码。
set order = 0;
loop over cust_id;
counter = 1;
order = order + 1;
loop over product_id
if (counter == 1 || counter == 6) {
if (counter == 6) {
counter == 1;
order= order+1;
}
field[order][1] = "field(1)"; // cust_id
field[order][2] = "field(2)"; // name
field[order][3] = "field(3)"; // phone
}
field[order][counter+3] = productCode; // product_1
field[order][counter+4] = quantity; // quantity_1
counter = counter + 1;
if (counter == 6) {
field[order][14] = "field(4)"; // trx_id
field[order][15] = "field(5)"; // total_cost
}
end inner loop;
if (counter == 6) {
// loop here to insert blank columns and the totals field to fill out the row.
}
end outer loop;有一件事我很担心。如果您每五个产品开始一行,那么您的交易id和总成本将被多次输入到文件中。你知道接收系统。这可能不是问题。
希望这能有所帮助
发布于 2010-11-30 08:01:16
在将数据放入行中时,需要检查产品数量是否超过5个,然后再创建一行。
loop over product_id
if (counter mod 10 == 0 and counter > 0) {
// create the new row, and mark it as a continuation of the previous order
counter = 0;
order = order + 1;
field[order][1] = "";
...
field[order][15] = "";
}
field[order[4+counter] = productCode;
field[order[5+counter] = quantity;
counter = counter + 2;
end inner loop;我实际上已经完成了从一个电子商务系统到MOM的导出,但是这个代码已经丢失了。我有经典的ASP的代码样本。
https://stackoverflow.com/questions/4307334
复制相似问题