PCB 电测试--测试点数自动输出到流程指示中(读取TGZ Stephdr文件)
好不容易实现了 《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文件)的更多相关文章
- hdu 1003 MAX SUM 简单的dp,测试样例之间输出空行
测试样例之间输出空行,if(t>0) cout<<endl; 这样出最后一组测试样例之外,其它么每组测试样例之后都会输出一个空行. dp[i]表示以a[i]结尾的最大值,则:dp[i ...
- IO&&Serize 利用线程Thread.Sleep实现"自动输出"
查看链接 https://github.com/jungle8884/C-.Net/tree/MyClassLibrary using System; using System.Collections ...
- 测试Oracle 11gr2 RAC 非归档模式下,offline drop数据文件后的数据库的停止与启动测试全过程
测试Oracle 11gr2 RAC 非归档模式下,offline drop数据文件后的数据库的停止与启动测试全过程 最近系统出现问题,由于数据库产生的日志量太大无法开启归档模式,导致offline的 ...
- Atitit.mybatis的测试 以及spring与mybatis在本项目中的集成配置说明
Atitit.mybatis的测试 以及spring与mybatis在本项目中的集成配置说明 1.1. Mybatis invoke1 1.2. Spring的数据源配置2 1.3. Mybatis ...
- 利用javascript实现文本的自动输出
主要利用了setTimeout(),递归和String.substring(); 做出的效果就像是有一个打字员在打字. <!doctype html> <html lang=&quo ...
- Mysql取随机数据效率测试(400W条中读取100条)
测试数据表的创建在文章:http://www.cnblogs.com/wt645631686/p/6868192.html 先看一下我的SQL方案 SELECT * FROM `emp` WHERE ...
- top 自动执行的shell脚本中,使用top -n 1 > log.txt, 上电自动执行,文件无输出
. 自动执行的shell脚本中,使用top -n > log.txt, 上电自动执行,文件无输出,使用一下命令解决: //usr/bin/top -d -n -b > log.txt 如果 ...
- 测试,测试开发,QA,QM,QC--------- 测试之路勿跑偏
测试,测试开发,QA,QM,QC可能是测试行业里的细分角色了,加了不少群学习,看到不同人有对自己不同的角色定位.我也做了这挺长时间的测试,也和大部分测试同胞一样,为了一份好的工作学习各种各样的技术,但 ...
- 配置-XX:+HeapDumpOnOutOfMemoryError 对于OOM错误自动输出dump文件
配置-XX:+HeapDumpOnOutOfMemoryError 对于OOM错误自动输出dump文件 学习了:http://blog.csdn.net/stevendbaguo/article/de ...
随机推荐
- C/C++ 之数组排序
#include <stdio.h> #include <stdlib.h> void array_sort(int *a, int len) { int i, j, tmp; ...
- How To:防火墙规则去重
主要命令 iptables-save| awk ' !x[$0]++ | iptables-restore 演示: [root@testname ~]# iptables -vL Chain INPU ...
- 【解题报告】 洛谷 P3492 [POI2009]TAB-Arrays
[解题报告] 洛谷 P3492 [POI2009]TAB-Arrays 这题是我随机跳题的时候跳到的.写完这道题之后,顺便看了一下题解,发现只有一篇题解,所以就在这里顺便写一个解题报告了. 首先当然是 ...
- 小白神器 - 一篇博客学会CSS
一. 简介 1. css定义 CSS是Cascading Style Sheets的简称,中文称为层叠样式表. 属性和属性值用冒号隔开,以分号结尾. 2. 四种引入方式 1.行内式 行内式是在标签 ...
- 小白神器 - Django - 起步
小白神器 - Django - 起步 一. Django下载 1. 命令行 pip install django==1.11.16 pip install django==1.11.16 -i ht ...
- cuda npp库旋转图片
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <assert.h&g ...
- PAT 1099. Build A Binary Search Tree (树的中序,层序遍历)
A Binary Search Tree (BST) is recursively defined as a binary tree which has the following propertie ...
- BUPT2017 springtraining(15) #3
这里这里 A.签到题 #include <cstdio> double a[] = {0.4, 0.16, 0.063, 0.025, 0.010, 0.004}; int main() ...
- Codeforces Round #411(Div. 2)——ABCDEF
30min水掉前面4T,30min尝试读懂EF题,60min划水 顺便D忘记取膜丢50分,距比赛结束10s时hack失败丢50分... 从2620掉分到2520,从rank227掉到rank354.. ...
- Android欢迎页面以及引导页面
开发环境:Windows 10 x64,Android Studio 3.0 很多APP都会在启动主界面(MainActivity)之前显示一个短暂的欢迎页面,设置微博,知乎,百度之类APP还是在欢迎 ...