首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Mom文件创建(5个产品限制)

Mom文件创建(5个产品限制)
EN

Stack Overflow用户
提问于 2010-11-30 03:36:41
回答 2查看 121关注 0票数 0

好吧,我知道这是一个非常小众的问题,但我希望这个过程足够直接……

我的任务是根据客户/订单信息创建数据文件。问题是,数据文件有5个产品的最大限制。

基本上,我得到我的数据,按cust_id分组,创建文件结构,在该循环中,按product_id分组,用新产品信息重写以前file_struct中的字段。这一切都运行得很好,直到用户超过了最大值。

一个简单的例子..

代码语言:javascript
复制
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,在文本字段中开始一个新行,但我不知道如何到达那里。

我已经尝试了许多修复,但没有一个能给出我需要的结果。

EN

回答 2

Stack Overflow用户

发布于 2010-11-30 07:52:02

您需要将页眉和页脚字段的插入移动到产品循环中,例如。custid和trx_id字段。

这里有一个粗略的想法,为什么你可以基于你提供的伪代码来做这件事。我相信你可以用更优雅的方式来编写代码。

代码语言:javascript
复制
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和总成本将被多次输入到文件中。你知道接收系统。这可能不是问题。

希望这能有所帮助

票数 0
EN

Stack Overflow用户

发布于 2010-11-30 08:01:16

在将数据放入行中时,需要检查产品数量是否超过5个,然后再创建一行。

代码语言:javascript
复制
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的代码样本。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4307334

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档