好不容易实现了 《PCB 无需解压,直接读取Genesis TGZ指定文件 》

正好这里有一项需求:PCB电测试--测试点数自动输出到流程指示中

一.自动输出测试点小结;

1.由于历史原因;各工厂差异,测试点数统计单位差异,有的工厂为PCS计算测试点,有些工厂一年前是按PCS计算测试点,而最新测试点是以PNL计算;

而流程指示中统一为PNL为测试点单位统计,在制作前,要识别此坑,不要往里面跳了。

2.另一个,有些客户来的CAM资料是Set为单位,工程CAM制作时是不会再拆为PCS作业,而之前的规则是以PCS计算测试点的,而此测试点数是以SET计算测试点,

而转为PNL测试点时,无法准确测试点数的单位到底是SET还是PCS,可能导致转为PNL测试点错误。

3.基于以上2点问题,解决方法是:读取TGZ  Stephdr拼板及工程标准命名规范识别PNL中拼了多少个SET,多少个PCS。计算出转换值。

二.读取TGZ  Stephdr文件

        /// <summary>
/// 读取stephdr
private void readStephdr()
{
Dictionary<string, List<STEP_REPEAT>> dicStepRepeat = new Dictionary<string, List<STEP_REPEAT>>();
string tarFilePath = @"F:\2p00802ya0.tgz";
string FileName = Path.GetFileNameWithoutExtension(tarFilePath);
string FindDir = $@"{FileName}/steps/"; //以/斜杆结尾为文件夹
using (Stream stream = File.OpenRead(tarFilePath))
{
IReader reader = ReaderFactory.Open(stream);
while (reader.MoveToNextEntry())
{
Match matchresult = Regex.Match(reader.Entry.Key, $@"^{FindDir}([\w\s]+)/stephdr$");
if (matchresult.Success)
{
string StepName = matchresult.Groups[].Value;
using (EntryStream st = reader.OpenEntryStream())
{
byte[] byData = new byte[reader.Entry.Size];
st.Read(byData, , byData.Length);
string STEP_REPEAT_txt = System.Text.Encoding.Default.GetString(byData);
List<STEP_REPEAT> STEP_REPEATlist = Info2STEP_REPEAT(STEP_REPEAT_txt);
dicStepRepeat.Add(StepName, STEP_REPEATlist);
}
}
}
}
List<STEP_REPEAT> STEP_REPEATpnl = new List<STEP_REPEAT>();
if (dicStepRepeat.ContainsKey("pnl"))
{
STEP_REPEATpnl = dicStepRepeat["pnl"];
getAllChild_STEP_REPEAT(STEP_REPEATpnl, dicStepRepeat);
}
int count_ = getStepCount(STEP_REPEATpnl, ".*", false);
}
/// <summary>
/// 获取PNL中有多个拼板个数
/// </summary>
/// <param name="STEP_REPEATpnl">PNL STEP_REPEAT信息</param>
/// <param name="Fillter">过滤Step名</param>
/// <param name="NotRecursion">是否递归深入搜索</param>
/// <returns></returns>
public int getStepCount(List<STEP_REPEAT> STEP_REPEATpnl, string Fillter = "(cam|set|flip).*", bool NotRecursion = false)
{
if (STEP_REPEATpnl == null || STEP_REPEATpnl.Count == )
return ;
int SumCount = ;
foreach (var item in STEP_REPEATpnl)
{
if (Regex.IsMatch(item.NAME, Fillter))
{
if (NotRecursion)
SumCount += item.NX * item.NX;
else
SumCount += item.NX * item.NX * getStepCount(item.STEP_REPEAT_List, Fillter);
}
}
return SumCount;
}
/// <summary>
/// 获取PNL做为父节点 获取拼板关系(PNL->SET->CAM) 递规实现
/// </summary>
/// <param name="STEP_REPEATpnl"></param>
/// <param name="dicStepRepeat"></param>
public void getAllChild_STEP_REPEAT(List<STEP_REPEAT> STEP_REPEATpnl, Dictionary<string, List<STEP_REPEAT>> dicStepRepeat)
{
if (STEP_REPEATpnl == null || STEP_REPEATpnl.Count == )
return;
foreach (var item in STEP_REPEATpnl)
{
if (dicStepRepeat.ContainsKey(item.NAME))
{
item.STEP_REPEAT_List = dicStepRepeat[item.NAME];
getAllChild_STEP_REPEAT(item.STEP_REPEAT_List, dicStepRepeat);
}
}
}
/// <summary>
/// 读取Step Stephdr文件信息到Mod
/// </summary>
/// <param name="STEP_REPEAT_txt"></param>
/// <returns></returns>
public List<STEP_REPEAT> Info2STEP_REPEAT(string STEP_REPEAT_txt)
{
List<STEP_REPEAT> STEP_REPEATlist = new List<winTool.STEP_REPEAT>();
string[] lines = STEP_REPEAT_txt.Split('\n');
bool isStart = false;
STEP_REPEAT ModStep = new STEP_REPEAT();
foreach (var item in lines)
{
if (isStart)
{
string[] itemArray = item.Split('=');
if (itemArray.Length == )
{ string itemKey = itemArray[].Trim();
string itemVal = itemArray[].Trim();
switch (itemKey)
{
case "NAME":
ModStep.NAME = itemVal.ToLower();
break;
case "X":
ModStep.X = Double.Parse(itemVal);
break;
case "Y":
ModStep.Y = Double.Parse(itemVal);
break;
case "DX":
ModStep.DX = Double.Parse(itemVal);
break;
case "DY":
ModStep.DY = Double.Parse(itemVal);
break;
case "NX":
ModStep.NX = int.Parse(itemVal);
break;
case "NY":
ModStep.NY = int.Parse(itemVal);
break;
case "ANGLE":
ModStep.ANGLE = Double.Parse(itemVal);
break;
case "MIRROR":
ModStep.MIRROR = itemVal == "YES" ? true : false;
break;
}
}
else if (item.StartsWith("}"))
{
isStart = false;
STEP_REPEATlist.Add(ModStep);
}
}
else if (!isStart && item.StartsWith("STEP-REPEAT") && item.EndsWith("{"))
{
isStart = true;
ModStep = new STEP_REPEAT();
}
}
return STEP_REPEATlist;
}

Stephdr  Mod类

    public class STEP_REPEAT
{
public string NAME { get; set; }
public double X { get; set; }
public double Y { get; set; }
public double DX { get; set; }
public double DY { get; set; }
public int NX { get; set; }
public int NY { get; set; }
public double ANGLE { get; set; }
public bool MIRROR { get; set; }
public List<STEP_REPEAT> STEP_REPEAT_List { get; set; }
}

三.读取 ZIP 测试点文件

        private void readTestPoint()
{
int resultCount = ;
string tarFilePath = @"F:\4a00n0nb.zip";
string FileName = Path.GetFileNameWithoutExtension(tarFilePath);
using (Stream stream = File.OpenRead(tarFilePath))
{
IReader reader = ReaderFactory.Open(stream);
while (reader.MoveToNextEntry())
{
if (reader.Entry.Key.EndsWith("profile.cmb"))
{
using (EntryStream st = reader.OpenEntryStream())
{
byte[] byData = new byte[reader.Entry.Size];
st.Read(byData, , byData.Length);
string result = System.Text.Encoding.Default.GetString(byData);
resultCount = int.Parse(result);
break;
}
}
}
}
}

PCB 电测试--测试点数自动输出到流程指示中(读取TGZ Stephdr文件)的更多相关文章

  1. hdu 1003 MAX SUM 简单的dp,测试样例之间输出空行

    测试样例之间输出空行,if(t>0) cout<<endl; 这样出最后一组测试样例之外,其它么每组测试样例之后都会输出一个空行. dp[i]表示以a[i]结尾的最大值,则:dp[i ...

  2. IO&&Serize 利用线程Thread.Sleep实现"自动输出"

    查看链接 https://github.com/jungle8884/C-.Net/tree/MyClassLibrary using System; using System.Collections ...

  3. 测试Oracle 11gr2 RAC 非归档模式下,offline drop数据文件后的数据库的停止与启动测试全过程

    测试Oracle 11gr2 RAC 非归档模式下,offline drop数据文件后的数据库的停止与启动测试全过程 最近系统出现问题,由于数据库产生的日志量太大无法开启归档模式,导致offline的 ...

  4. Atitit.mybatis的测试  以及spring与mybatis在本项目中的集成配置说明

    Atitit.mybatis的测试  以及spring与mybatis在本项目中的集成配置说明 1.1. Mybatis invoke1 1.2. Spring的数据源配置2 1.3. Mybatis ...

  5. 利用javascript实现文本的自动输出

    主要利用了setTimeout(),递归和String.substring(); 做出的效果就像是有一个打字员在打字. <!doctype html> <html lang=&quo ...

  6. Mysql取随机数据效率测试(400W条中读取100条)

    测试数据表的创建在文章:http://www.cnblogs.com/wt645631686/p/6868192.html 先看一下我的SQL方案 SELECT * FROM `emp` WHERE ...

  7. top 自动执行的shell脚本中,使用top -n 1 > log.txt, 上电自动执行,文件无输出

    . 自动执行的shell脚本中,使用top -n > log.txt, 上电自动执行,文件无输出,使用一下命令解决: //usr/bin/top -d -n -b > log.txt 如果 ...

  8. 测试,测试开发,QA,QM,QC--------- 测试之路勿跑偏

    测试,测试开发,QA,QM,QC可能是测试行业里的细分角色了,加了不少群学习,看到不同人有对自己不同的角色定位.我也做了这挺长时间的测试,也和大部分测试同胞一样,为了一份好的工作学习各种各样的技术,但 ...

  9. 配置-XX:+HeapDumpOnOutOfMemoryError 对于OOM错误自动输出dump文件

    配置-XX:+HeapDumpOnOutOfMemoryError 对于OOM错误自动输出dump文件 学习了:http://blog.csdn.net/stevendbaguo/article/de ...

随机推荐

  1. VHDL之Serial-Parallel Multiplier

    1 Serial-parallel multiplier Figure 12.1 shows the RTL diagram of a serial-parallel multiplier. One ...

  2. iptables详解(3):iptables规则管理

    所属分类:IPtables  Linux基础 在本博客中,从理论到实践,系统的介绍了iptables,如果你想要从头开始了解iptables,可以查看iptables文章列表,直达链接如下 iptab ...

  3. time模块和datatime模块

    一.time模块 time.time() 获取时间戳 time.sleep() 睡几秒 time.gmtime() utc时间元组 time.localtime() 本地时间元组 time.mktim ...

  4. 【Linq】

    " }; var l1 = strs.ToLookup(a => "a"); //Key=a elements=1,3 var l2 = strs.ToLookup ...

  5. JavaScript:一句代码输出重复字符串(字符串乘法)

    看到一个题目要求写一个函数times,输出str重复num次的字符串. 比如str:bac     num:3 输出:abcabcabc 除了利用循环还有几种方法,我学习研究之后记下以下三种方法. 1 ...

  6. C++实现双人枪战游戏

    //单机版枪战游戏,喜欢就拿走,把赞留下//by floatiy #include<iostream> #include<cstdio> #include<windows ...

  7. 关于预测io调用的思考

    什么是预测io 预测io是linux2.6版本内核调用默认的调用程序,对应用程序进行跟踪,统计应用程序使用io情况,在读操作返回之前先停顿6ms时间(linux默认时间),如果这期间有读操作过来,可以 ...

  8. 【http反向代理】多个域名指向同一个ip的不同网站解决方法

    一个服务器需要挂载多个项目[重点是都能通过域名访问] 实现原理: 1.当前市面上看到的一些服务器,开放的端口一般都要求为 '80' 端口 所以80端口成了商用端口 2.域名的绑定是绑定一个一般是绑定你 ...

  9. MySQL数据库操作(一)

    一.数据操作 1.显示数据库 show databases; 2.创建数据库 #utf- create database 数据库名称 default charset utf8 collate utf8 ...

  10. nginx的安装部署以及使用

    [介绍] nginx是现在互联上非常流行的高性能的 Web 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器. 现在很多互联网应用都使用nginx来作为负载均衡的使用,再高并发 ...