zoukankan      html  css  js  c++  java
  • [源代码]

    在前文 [源代码] - C#代码搜索器 中我开发了一个代码搜索器. 我对其做的最后改动是将索引保存到磁盘中, 以备今后使用.

    如今, 我在工作中又接到一项新任务: 有一个大项目, 其中10个负责数据访问的service即将被淘汰, 将会替换成entity framework的方式. 这10个service一共有近130个operation. 项目中所有调用这些operation的地方都必须被替换成新的EF方式. 整个项目有47902个cs文件. 现在要做个分析, 找到所有需要修改的地方.

    稍作思考, 开工! 

    先创建一个console project, 引入WEBUS2.0 SDK. 将10个service和130个operation的信息放到字符串数组中:

    static string[] DS_OP_List = new string[] {
        "xxxxDS.CalculatePilotCloseOut",
        "xxxxDS.CreatexxFirstAcont",
        "xxxxDS.CreatexxUnallocatedULD",
        "xxxxDS.xxCargoGetTare",
        "xxxxDS.xxCargoCreateAbulk",
        "xxxxDS.xxCargoDeleteAbulk",
        "xxxxDS.xxCargoMoveAbulk"
        ...
    }; //共130个, 公司有规定, 所以用xxx替代真实值 :)

    然后打开Index (关于如何创建Index请参见前文:  [源代码] - C#代码搜索器), 再循环对operation进行搜索:

    static void Main(string[] args)
    {
        IIndexer index = new IndexManager(); //构造索引对象
        index.Open(@"C:xxxCodeSearch.Index", IndexOpenMode.Read); //以只读方式打开索引
        ISearcher se = new IndexSearcher(index); //构造搜索对象
        using (CSVFile csv = new CSVFile(@"c:	empxx_DS_Analysis.csv")) //将结果保存在csv文件中
        {
            foreach (var ds_op in DS_OP_List)
            {
                var key = ds_op.Split('.')[1].ToLower(); //从Service.Operation中提取Operation, 比如从xxxxDS.CalculatePilotCloseOut中提取CalculatePilotCloseOut中提取
                var hits = se.Search(string.Format("Code="{0}"", key)); //搜索表达式: Code="CalculatePilotCloseOut"
                Console.WriteLine("{0}/{1}", key, hits.Count);
                foreach (HitDoc hit in hits)
                {
                    csv.Write(ds_op, hit.GetDoc().GetField("FileName").Value.ToString()); //依次输出"服务名", "方法名", "文件名"到csv中
                }
            }
        }
        Console.ReadLine();
    }

    最后上一个生成CSV文件的工具类:

    public class CSVFile : IDisposable
    {
        public string FileName { get; private set; }
        private StreamWriter sw = null;
        private StreamReader sr = null;
        private FileStream fsWrite = null;
        private FileStream fsRead = null;
    
        public CSVFile(string filename)
            : this(filename, Encoding.UTF8, FileMode.OpenOrCreate)
        {
        }
    
        public CSVFile(string filename, FileMode mode)
            : this(filename, Encoding.UTF8, mode)
        {
        }
    
        public CSVFile(string filename, Encoding encoding, FileMode mode)
        {
            this.FileName = filename;
            fsWrite = new FileStream(filename, mode, FileAccess.Write, FileShare.Read);
            fsWrite.Seek(0, SeekOrigin.End);
            fsRead = new FileStream(filename, FileMode.Open, FileAccess.Read, FileShare.ReadWrite);
            sw = new StreamWriter(fsWrite, encoding);
            sr = new StreamReader(fsRead, encoding);
        }
    
        public void Close()
        {
            sw.Close();
            sr.Close();
        }
    
        public string[] Read()
        {
            string text = sr.ReadLine();
            if (string.IsNullOrEmpty(text))
            {
                return null;
            }
            return text.Split(',');
        }
    
        public string[] FindNext(string startKeyword, StringComparison comparisonType = StringComparison.InvariantCultureIgnoreCase)
        {
            string[] result = null;
            while ((result = this.Read()) != null)
            {
                if (result[0].StartsWith(startKeyword, comparisonType))
                {
                    return result;
                }
                else
                {
                    continue;
                }
            }
            return null;
        }
    
        public void Write(params string[] values)
        {
            StringBuilder sb = new StringBuilder();
            foreach (var v in values)
            {
                sb.Append(v + ",");
            }
            sw.WriteLine(sb.ToString().Substring(0, sb.Length - 1));
        }
    
        public void Dispose()
        {
            this.Close();
        }
    }
    View Code

    ok, 大功告成! 运行:

  • 相关阅读:
    django静态资源转移
    QT5 内置Multimedia开发音乐播放器
    Qt Creator 设置编码格式为 UTF-8
    QT 出错 moc_mainwindow.obj:-1: error: LNK2019: 无法解析的外部符号 " 中被引用...
    linux 安装node, 添加软链接,更改npm安装源
    django.template.exceptions.TemplateDoesNotExist: index.html
    centos下使用virtualenv建立python虚拟环境
    win7上 nginx 出现 403 Forbidden
    django安装xadmin中出现的报错汇总
    centos安装mysql57
  • 原文地址:https://www.cnblogs.com/iamzyf/p/3270789.html
Copyright © 2011-2022 走看看