tcl调用linux命令的简单介绍

工作中总结的常用linux命令(Ⅱ)

[1] 每两行合并在一起

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:网站建设、做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的丽水网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

@dahuawk 'ORS=NR%2?" ":"\n"{print}'

[2] 每三行合并在一起

@dahuawk 'ORS=NR%3?" ":"\n"{print}'

[3] 每四行合并在一起

@dahuawk 'ORS=NR%4?" ":"\n"{print}'

[4] 统计std cell和sRam占的面积

@dahusummaryReport

[5] 找出drc的port相关的数量

@dahucat postroute_opt.drc | grep -B1 Type: | grep -v Type: | grep "\[" |-

[6] 获得选中的pin的名字

@innovusdbget selected.name

[7]  对一个文件,多目标删除

@dahused -i 's/MODE1\|MODE2\|MODE3\|MODE4\|MODE5//g'

[8] 获得不规则fplan的坐标组

@innovusdbget top.fplan.boxes

[9] 在某个目录下找到带某个字符的文件[区分大小写]

@dahufind -iname "*tcic*"

[10] 在某个目录下,遍历所有文件内容,得到含有某个字符/字符串的行

@dahugrep -r 'insertion delay' ./

[11] 查看当前的INNOVUS版本号

@dahuecho $INVS_VER

[12] 替换某个目录下所有文件内容

@dahused -i"s/查找的内容/替换后的内容/g"`grep -rl"查找的内容"./`

[13] 在gui界面下highlight某条path

@dahu ctd_trace -from *  -to *  -color *

[14] 引用${REV},为什么采用大括号{}

为了防止引用造成后面错乱。

如:/fs/omp_com_03/RELEASE/top2hlb/R1/HLB_DEF/${REV}/${top}.def.gz

[15] 解压命令

gzip -d FileName.gz

[16] 换某个cell的坐标 {AAA, BBB}

@innovus dbset [dbget top.inst.name XXXXXXXX].pt_x AAA

@innovus dbset [dbget top.inst.name XXXXXXXX].pt_y BBB

@innovus zoomSelected

[17] 设置某一个cell不用

@innovus set_dont_touch BUFF false

@innovus set_dont_touch BUFF true

[18] 找某个性质

@innovus dbSet [].?h

[19] 删去空白行

vim 中:g/^s*$/d

简单解释一下:

g :全区命令

/ :分隔符

^s*$ :匹配空行,其中^表示行首,s表示空字符,包括空格和制表符,*重复0到n个前面的字符,$表示行尾。连起来就是匹配只有空字符的行,也就是空行。

/d :删除该行

[20] echo 写入带有双引号""的内容。

echo ‘ “AAAbbb” ’ 1.tcl

[21] echo 写入带有单引号‘’的内容。

echo “ ‘AAAbbb' ” 1.tcl

[22] keep CPU 数目

@innovussetMultiCpuUsage -localCpu 16

@innovushistory keep 999999

[23] 打开xlsm文件

openoffice.org 文件

[24] 显示clock path路径

@innovus report_timing -to XXX -path_type full_clock

[25]报出没有被约束到的path

@innovus report_timing -to XXX -uncounstrained

[26]报出穿过path中的某一点

@innovus report_timing -to XXX -view

view = MODE + corner

[27] vim 全选(高亮显示 ):按esc后,然后ggvG或者ggVG

[28]

如何编程调用linux系统命令

首先,命令应该是好和其他两个区分开来的了,因为命令都是可以直接敲在shell上面回车执行的,而系统调用和库函数都不行;

其次,百Linux系统调用和C库函数都是函数的形式,即都是“func(args)”的形式,但系统调用是

由系统内核对外提供的服务接口;C库函数和你自己写的普通的函数没有本质的区别,只是在度C标准库中而已,Linux上面glibc就是C函数库。从表专面上看两者不太好区分,不过,你可以从它们需要包含的头文件来区分,C库函数像printf在stdio.h中,std就是标准(standard)的缩写形式,因此在stdxxx.h中的函数,基本都是C库函数;像

ssize_t

read(int

fd,

void

*buf,

size_t

count);这样很多的系统调用是包含在unistd.h中的,unistd意思是UNIX

Standard,从这个意义就可以区分了。

希望对你有所帮助,如还有问题,可随属时联系我:-)

linux 如何运行tcl

1. 创建

例如想创建一个 *.tcl的文件,只需在终端中输入

touch *.tcl 即可

2. 编译

可用不同的编译器对 *.tcl文件进行编译

1 vi *.tcl

2 vim *.tcl

3 gedit *.tcl

3. 运行

我是用ns2运行*.tcl文件的

所以运行时输入的就是

ns *.tcl

TCL脚本在linux下怎么执行

你的linux装了tcl解释器了吗,一般是

/usr/bin/tclsh,如果确认你装了

(确认方法是在命令行下执行

tclsh),如果没问题,就在你的TCL脚本第一行加上

#!/usr/bin/env

tclsh

然后确保你的脚本(假定脚本名字叫test.tcl)

是可执行的

(chmod

+x

test.tcl)

然后直接运行

./test.tcl

即可。


名称栏目:tcl调用linux命令的简单介绍
转载来源:http://cdiso.cn/article/dssjiej.html

其他资讯