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
5
# 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個子類別的合計數的佔比。