• 在Axapta中实现split函数


    在Axapta中没有找到类似于C#中的split函数,在SQL Server中也没有类似的函数,当初写SQL函数的时候用了SQL Server中的系统函数charindex和substr来实现这样的功能,于是首先想到了用函数strFind和subStr来实现split函数.下列代码可以分解一个字符串并打印:

    static void split(Args _args)
    {
        
    int position;
        str srcStr;
        ;
        srcStr 
    = "AA,BB,CC,";

        
    while(true)
        
    {
            position 
    = strFind(srcStr,",",1,strlen(srcStr));
            
            
    if(!position)
            
    {
                print(srcStr);
                
    break;
            }


            print(subStr(srcStr,
    1,position-1));
            srcStr 
    = subStr(srcStr,position+1,strlen(srcStr)-position);
        }

        pause;

    }
    上面的代码显得臃肿并且很容易出错,因为要考虑边界情况,如果用Axapta中的Container实现这个功能就优雅得多,代码如下:
    static void Split2(Args _args)
    {
        Container c;
        str srcStr;
        
    int i;
        ;
        srcStr 
    = "AA,BB,CC,";

        c 
    = Global::str2con(srcStr,",");
        
    for(i=1;i<=conlen(c);i++)
        
    {
            print(conpeek(c,i));
        }

        pause;


    }
    当然如果查看str2con的代码就会知道,str2con也是用了strScan和substr对字符串进行分析处理,不过眼不见心不烦,不是吗?呵呵.另外str2con用函数match判断了字符串如果可以转换成数字,就会把字符串转换成数字,这点不够可爱,可以自己写一个str2conXpp之类的,把这个match去掉.
  • 相关阅读:
    Kubernetes日志的6个最佳实践
    如何选出适合自己的管理Helm Chart的最佳方式?
    授权权限服务设计解析
    微服务中如何设计一个权限授权服务
    微服务中的网关
    ketchup服务治理
    ketchup 消息队列rabbitmq使用
    ketchup 注册中心consul使用
    微服务框架 ketchup 介绍
    微服务框架surging学习之路——序列化
  • 原文地址:https://www.cnblogs.com/Farseer1215/p/502468.html
Copyright © 2020-2023  润新知