語法
csplit [ -f Prefix ] [ -k ] [ -n Number ] [ -s ] File Argument ...
描述
csplit 命令拷貝指定的檔案並將拷貝分成段。原始的還未改變的輸入檔案,必須是一個文本檔案。
這個 csplit 命令將這些段寫到檔案 xx00 . . . xx99 中,這依賴於 Argument 參數被指定(99 是最大值)多少次。預設情況下,Argument 參數期望一個行號。當指定多行號時套用以下規則:
* 檔案 xx00 包含原始檔案的行開始,到(但不包括)第一個 Argument 參數指定的行。
* 檔案 xx01 包含第一個 Argument參數指定的編號的行開始,直到(但不包括)第二個 Argument參數引用的行。每個指定行號作為自變數,標記新行的開始。
* 檔案 xxnn(最後創建的檔案)包含最後一個 Argument 參數指定的編號的行開始,直到檔案結束。
示例
如果原始的檔案有 108 行,輸入:
csplit orginal.txt 11 72 98
這個 csplit 命令創建 4 個檔案: xx00 檔案包含行 1-10,xx01 檔案包含行 11-71,xx02 檔案包含行 72-97,xx03 檔案包含行 98-108。
Argument 參數還可以包含以下符號和模式字元串:
/Pattern/ 創建一個檔案包含從當前行開始直到(但不包含)包含指定模式的那一行的段的檔案。包含模式的行成為當前行。
% Pattern % 使包含指定模式的行成為當前行,但不為段創建一個檔案。
+ Number 將指定編號的行從以前的匹配模式前移。示例,/頁 /+5 搜尋頁,那就提前 5 行。
-Number 將指定的行號從以前的匹配模式行後移。示例,/頁 /-5 搜尋頁那就後退 5 行。
{Number} 重複指定次數的以前選項。這個號碼可以緊跟任何模式或行號。如果緊跟一個模式,csplit 命令就會重新使用指定次數的模式。如果緊跟一個行號,csplit 命令將檔案從由行號指定行的點處分割開。
將引用標記放在所有模式周圍,這些模式包含空格或其它專用於 shell 的字元。模式不要包含 embedded 新行字元。在表達中,例如 [a-z],- (減號)意思是通過,這是根據當前的整理順序。一個整理順序可以定義同等的類以便在字元範圍以內使用。
標誌
-fPrefix 指定前綴由已經創建的區塊使用。此變數的預設值是 xx。
-k 使創建的區塊完整的位於出錯事件中。
-nNumber 改變十進制號碼位,用於創建檔案名稱。預設的是兩個十進制位或 xx00 . . . xx99。 如果指定 -n 4 標誌,例如,新的檔案被命名為 xx0000 . . . xx0099。
-s 消除字元計數的顯示。
退出狀態
此命令返回以下退出值:
0 成功完成。
>0 發生錯誤。
示例
1. 將 book 的文本以每章一個單獨檔案來分割,輸入:
csplit book "/^ Chapter *[k.0-9]k./" {9}
這創建了 10 個檔案,從 xx00 到 xx09。xx00 檔案包含了第一章前面的出版前頁。檔案從 xx01 到 xx09 包含各個單獨的章節。每一章起始的一行只包含單詞章和章節號。
2. 為這些創建自 book 的檔案指定前綴 chap,輸入:
csplit -f chap book "/^ Chapter *[k.0-9]k./" {9}
這樣把 book 分割成檔案,命名從 chap00 到 chap09。
檔案
/usr/bin/csplit 包含 csplit 命令。