calculate - linux

来源:趣味经验馆 8.59K

calculate linux

Calculate Linux是俄罗斯语的基于Gentoo的发行和自启动运行DVD,其目标在于能在任意数量的计算机上都易于使用、安装和升级。它提供两种版 本,Calculate Linux Desktop(CLD)和Calculate Linux Server(CLS)。

小编还为您整理了以下内容,可能对您也有帮助:

Linux 里面命令行打开计算器 怎么输入

linux命令行计算器

详细文档请 man bc

在windows下,大家都知道直接运行calc,(c:windowssystem32calc.exe),可以打开计算器。

注:

calculate vt.&vi.

计算;calculator n. 计算器。calc就是这个计算的简写。

Ca在化学中是代表钙元素,calcium 

钙(20号元素,符号Ca)。两者有什么联系呢?

calculate 来自calculus,原义是做算术运算的小石子,是calx(石灰石)的小称。

那么在linux系统下,有无与windows下calc.exe类似的计算器呢?

下面总结linux下的三个命令,来介绍一下linux下的计算方法:

1)bc

bc在默认的情况下是个交互式的指 令。在bc工作环境下,可以使用以下计算符号:

+ 加法

- 减法

* 乘法

/ 除法

^ 指数

% 余数

如:

#

bc

bc 1.06

Copyright 1991-1994, 1997, 1998, 2000 Free Software Foundation,

Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

3+6           

<=加法

9.4+2*3          <=加法、乘法

10.(4+2)*3        <=加法、乘法(优先)

18.4*6/8         

<=乘法、除法

3.10^3         

 <=指数

1000

18%5           <=余数

3+4;5*2;5^2;18/4     

<=一行输入多个计算,用;相隔。

7.10

25

4.quit            <=退出

# bc

bc 1.06

Copyright 1991-1994, 1997, 1998, 2000 Free Software Foundation,

Inc.

This is free software with ABSOLUTELY NO WARRANTY.

For details type `warranty'.

scale=3        

<=设小数位

1/3

.333

quit

以上是交互的计算,那到也可以 不进行交互而直接计算出结果。

A.用echo和|法,如:

# echo "(6+3)*2" |bc

18.# echo 15/4 |bc

3.# echo "scale=2;15/4"

|bc

3.75

# echo "3+4;5*2;5^2;18/4"

|bc

7.10

25

4. 

另外,

bc除了scale来设定小数位之外,还有ibase和obase来其它进制的运算。

如:

//将16进制的A7输出为10进制, 注意,英文只能大写

# echo "ibase=16;A7"

|bc

167

//将2进制的11111111转成10进制

# echo "ibase=2;11111111"

|bc

255

//输入为16进制,输出为2进制

# echo "ibase=16;obase=2;B5-A4"

|bc

10001

对于bc还有补充,在bc --help中还可以发现:bc后可以接文件名。如:

# more calc.txt

3+2

4+5

8*2

10/4

# bc calc.txt

5.9

16.2.2)expr

expr命令可不光能计算加减乘除哦,还有很多表达式,都可以计算出结果,不过有一点需要注意,在计算加减乘除时,不要忘了使用空格和转义。下

面直接用实例来介绍一下expr的运算,如:

# expr 6 +

3      

(有空格)

9. 

# expr 2 *

3     

(有转义符号)

6.# expr 14 % 9

# a=3

# expr

$a+5         

(无空格)

3+5

# expr $a +

5        

(变量,有空格)

8.#

a=`expr 4 + 2`

echo $a

6.# expr $a + 3

9.另外,expr对于字串的操作(计算)也是很方便的,如:

//字串长度

# expr length

"yanggang.cublog.cn"

21

//从位置处抓取字串

# expr substr "yanggang.cublog.cn"

1 11

yanggang

//字串开始处

# expr index

"yanggang.cublog.cn" cu

13. 

3)dc

用dc来进行计算的人可以不多,因为dc与bc相比要复杂,但是在进行简单的计划时,是差不多的,不算难。dc为压栈操作,默认也是交互的,但

也可以用echo和|来配合打算。

如:

# dc

3.2+

p

5.4*

p

20.quit

# echo 3 2+ 4* p |dc

20. 

4)echo

echo用来进行回显,是周知的事。上面也配合bc来进行计算。其实echo也可以单独进行简单的计算,如:

# echo $((3+5))

8.# echo $(((3+5)*2))

16. 

echo还可以进行变量的计算,如:

# a=10

# b=5

# echo $(($a+$b))

15.# echo $a+$b

10+5

# echo $a+$b |bc

15. 

//计算前天的日期

#  echo `date

+%Y%m%d`

20090813

#  echo `date +%Y%m%d`-2

20090813-2

#  echo `date +%Y%m%d`-2

|bc

20090811

5)AWK

awk在处理文件的时,可以进行运算,那当然也可以单单用来计算了,如:

# awk 'BEGIN{a=3+2;print

a}'

5.# awk 'BEGIN{a=(3+2)*2;print

a}'

10. 

Awk 支持常见的运算符, 如 + (加),- (减), * (乘), / (除), ^ 或 ** (乘方), % (取模)

等等。 此外, awk 也提供了一些常用的数学函数, 比如 sin(x), cos(x), exp(x), log(x),

sqrt(x), rand()。 使用这些运算符和函数可以直接进行一些简单的运算:

# echo | awk '{print

8+6}'

14.# echo | awk '{print

8/6}'

1.33333

# echo | awk '{print

9%5}'

4.请放心使用

有问题的话请追问

满意请及时采纳,谢谢

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

[1] 每两行合并在一起

<@dahu>awk 'ORS=NR%2?" ":"\n"{print}'

[2] 每三行合并在一起

<@dahu>awk 'ORS=NR%3?" ":"\n"{print}'

[3] 每四行合并在一起

<@dahu>awk 'ORS=NR%4?" ":"\n"{print}'

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

<@dahu>summaryReport

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

<@dahu>cat postroute_opt.drc | grep -B1 Type: | grep -v Type: | grep "\[" |-

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

<@innovus>dbget selected.name

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

<@dahu>sed -i 's/MODE1\|MODE2\|MODE3\|MODE4\|MODE5//g'

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

<@innovus>dbget top.fplan.boxes

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

<@dahu>find -iname "*tcic*"

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

<@dahu>grep -r 'insertion delay' ./

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

<@dahu>echo $INVS_VER

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

<@dahu>sed -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 数目

<@innovus>setMultiCpuUsage -localCpu 16

<@innovus>history 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]

CALCULATE 运算规则

一、关于CALCULATE 函数运算

筛选的三个层次:

1、公式内部筛选:上图中的 自定义公式 (黑色区域)  计算列或度量值

2、视图层筛选:上图中 公式中所在的图表(蓝色区域)   绿色区域内框定的部分

3、视图层之外的筛选: 上图中 公式所在图表之外的筛选(区域),针对绿色框定的部分,外部的切片器也是视图之外的筛选层。

筛选遵从的三个规则:

1、公式内部筛选可以覆盖视图层筛选, 不能覆盖视图层之外的筛选;

2、视图层筛选不能覆盖视图层外的筛选;

3、视图层筛选与外图层筛选取交集。

CALCULATE 改变外部环境的最后一次机会 : 1、筛选环境的修改;2、筛选器的修改。

上图公式呈现出值的计算过程:

KPI.Sales = SUM( 'Order'[LinePrice] )//计算订单的销售额

因为没有使用CALCULATE函数,所以,没有对外部筛选环境或筛选器进行修改,受视图层(蓝色区域)和视图层外部(区域)筛选影响(注:在案例中只有一个切片器,现实中可能还会有很多筛选)。

计算步骤:

1、视图层(蓝色区域)中 Category列和Subcategory对 KPI.Sales 计算进行筛选,如第一行办公用品、器具,在这两个字段中取的是交集,

2、视图层外部(区域)筛选的结果与视图层交集再取交集,

3、按第2步计算筛选的条件子集求和。

KPI.Sales.技术 = CALCULATE( [KPI.Sales] , 'Proct'[Category] = "技术" )

使用CALCULATE函数,对外部筛选环境或筛选器进行修改,可以覆盖掉视图层(蓝色区域)和视图层外部(区域)筛选影响。

这里有一个问题:不是公式中的筛选器可以覆盖掉公式以外的筛选器或修改器吗?为什么图中 2的位置是空值,而不是技术的值呢?

CALCULATE函数的计值过程:

计算步骤:

第1步:视图层(蓝色区域)中 Category列和Subcategory筛选,复制到CALCULATE当中,=> FC0 ;

第2步:CALCULATE 众多内部筛选器取交集,本例中只一个筛选'Proct'[Category] = "技术"=> FCn ;

第3步:第2步覆盖第1步,则取的是'Proct'[Category] = "技术" 这个子集 ;

值得注意的是,第2步覆盖第1步时,相同列覆盖掉的是相同列(Category),而不是其他列(subCategory);

第4步:因为'Proct'[SubCategory ]没有被覆盖,取'Proct'[SubCategory ] = "器具" ,与'Proct'[Category] = "技术" 的交集。

第5步:第4步的交集为空,所以,计算为0。

大王战友:图2处是空值的原因没有这么复杂的:环境上下文中,大类=办公用品 & 子分类=器具,与度量值中的大分类=技术, 这两个交集为0,所以=空值。

(这个计算过程的解释是错的,没有按CALCULATE的步骤进行计算)

KPI.Sales.Proct.All = CALCULATE( [KPI.Sales] , ALL( 'Proct' ) )

计算步骤:

第1步:视图层(蓝色区域)中 Category列和Subcategory筛选,复制到CALCULATE当中,=> FC0 ;

第2步:CALCULATE 众多内部筛选器取交集,本例中只一个筛选ALL( 'Proct' )=> FCn ;ALL  =  REMOVEFILTERS   清除所有外部筛选条件

第3步:第2步覆盖第1步,ALL清除了 Proct 表中所有列的筛选;

值得注意的是,第2步覆盖第1步时,覆盖掉的是环境上下文中的相同列(Category)和(subCategory),因为ALL清除了 Proct 表中所有列的筛选,可以理解为取了空集;

第4步:ALL清除了环境上下文(Category)和(subCategory)的筛选,所以,计算出来的是所有产品的总和。

注意:ALL清除了proct表的筛选,在环境上下文取得空集,外部切片器subcategory 对计算有影响,但是,因为环境上下文是空集,所以,计算结果仍是空集的结果。

如果在案例中增加 Customer 表的 Gender 切片器,ALL只清除了 Proct 表中所有列的筛选,而没有清除 Customer 表的筛选,计算出来的结果受 Gender 选项的影响。

KPI.Sales.Proct.AllSelected = CALCULATE( [KPI.Sales] , ALLSELECTED( 'Proct' ) )

ALLSELECTED 清除所有(视图层上下文)再选择(视图层外部的上下文)

计算步骤:

第1步:视图层(蓝色区域)中 Category列和Subcategory筛选,复制到CALCULATE当中,=> FC0 ;

第2步:CALCULATE 众多内部筛选器取交集,本例中只一个筛选   ALLSELECTED( 'Proct' ) ,清除了'Proct'的所有筛选=> FCn ; 

第3步:FCn覆盖FC0,ALLSELECTED清除了 Proct 表中所有列的筛选,计算 ;

值得注意的是,第2步覆盖第1步时,覆盖掉的是环境上下文中的相同列(Category)和(subCategory),因为ALL清除了 Proct 表中所有列的筛选;

第4步:ALL清除了环境上下文(Category)和(subCategory)的筛选,所以,计算了来的是所有产品的总和。

Sales.MktShare%.Proct.All = [KPI.Sales] / [KPI.Sales.Proct.All]

指标解释:如KPI是营业收入,那么,这个指标就是绝对占用,单一品类占的有品类的占比。

Sales.MktShare%.Proct.AllSelected = [KPI.Sales] / [KPI.Sales.Proct.AllSelected]

指标解释:如KPI是营业收入,那么,这个指标就是相对占用,ALLSELECTED是针对选择的指标占比,例如, 上述案例中就是对“器具、复印机、电话、配件和标签5个子类别的合计数的占比。

热门标签