當前位置:首頁 » 操作系統 » linuxfor遍歷文件

linuxfor遍歷文件

發布時間: 2022-06-27 04:26:20

『壹』 linux用for遍歷目標文件怎麼做

你這是Windows的批處理腳本,不能在linux下用的

『貳』 linux shell遍歷當前文件夾中的txt文件並處理生成新的文件

先以a.txt為例:

awk-vRS=""'{
n=split($0,a,"《[^》]+》");
for(i=2;i<n;i+=2)
print"《keywords》"a[i]"《/keywords》"
}'a.txt>>./newfile/a.txt

這樣就行了。

為了可讀性,我將一條awk語句寫成了多行。

實際測試結果如下:

解說:

RS=""

將awk的記錄分隔符設置為空(默認是換行符),即將整個a.txt文本看做一條記錄。

n = split($0,a,"《[^》]+》");

以正則"《[^》]+》"匹配的內容作為分隔符,對文本內容進行分割並將分割結果存入數組a,分割出的數目(數組大小)即為split函數的返回值n。這里暫且不對該正則做過多解釋,否則喧賓奪主,有需要請追問,我再補充。

for(i=2;i<n;i+=2)
print "《keywords》"a[i]"《/keywords》"

列印數組下標為偶數的元素並在首尾分別加上關鍵字標記以還原。數組下標從1開始。

其他文件可作相同處理。如果文件較多,你可以搞個循環去做。這個應該不難。

『叄』 怎麼使用java編程實現linux下所有文件目錄的遍歷

為了避免目錄列舉消耗時間過長,請指定一個目錄來模擬,命令行參數:代表路徑的字元串.
如果認可代碼,請加分50,謝謝

----

import javax.swing.*;
import javax.swing.tree.*;
import java.awt.*;
import java.io.*;
final public class FileTree extends JFrame {
public FileTree(File dir) throws HeadlessException {
super("File Tree");
JTree tree;
add(new JScrollPane(tree =new JTree(buildTreeModel(dir))));
tree.setCellRenderer(new FileTreeRenderer());
setSize(400,600);
setVisible(true);
}

private TreeModel buildTreeModel(File dir){
DefaultMutableTreeNode root = new DefaultMutableTreeNode(dir);
walkthrough(dir,root);
return new DefaultTreeModel(root);
}

private static void walkthrough(File f,DefaultMutableTreeNode node){
for (File fle : f.listFiles()) {
DefaultMutableTreeNode n = new DefaultMutableTreeNode(fle);
node.add(n);
if (fle.isDirectory()){
walkthrough(fle, n);
}
}
}

private class FileTreeRenderer extends DefaultTreeCellRenderer {
public Component getTreeCellRendererComponent(JTree tree, Object value, boolean sel, boolean expanded, boolean leaf, int row, boolean hasFocus) {
JLabel cmp = (JLabel)super.getTreeCellRendererComponent(tree, value, sel, expanded, leaf, row, hasFocus);
if (value instanceof DefaultMutableTreeNode) {
DefaultMutableTreeNode n = (DefaultMutableTreeNode)value;
Object obj = n.getUserObject();
if (obj instanceof File) {
File f = (File)obj;
cmp.setText(f.getName());
cmp.setForeground(f.isDirectory()?Color.BLUE:Color.BLACK);
}
}
return cmp;
}
}

public static void main(String[] args) {
new FileTree(new File(args[0]));
}
}

『肆』 linux shell中的遍歷目錄並刪除目錄下與目錄名相同的文件

先設定實驗環境:
#

5

目錄,每個目錄下,造
3

文件和兩個子目錄如下:
cd
$home/tmp
for
i
in
d1
d2
d3
d4
d5
do
mkdir
-p
$i
touch
$i/1.txt
$i/2.txt
$i/3.txt
mkdir
-p
$i/tmp1
$i/tmp2
done
#
檢驗測試環境:
$
ls
-lr
d1
total
0
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
1.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
2.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
3.txt
drwxr-sr-x
2
wenlee
comm
256
dec
22
10:35
tmp1/
drwxr-sr-x
2
wenlee
comm
256
dec
22
10:35
tmp2/
#
利用下列腳本來實現你要做的:
cd
$home/tmp
for
i
in
*/1.txt
do
echo
"found
$i,
save
$i
and
remove
everything
else
under
$(dirname
$i)/"
save_this_file=$(basename
$i)
curr_dir=$(dirname
$i)
#
把這個1.txt暫時存到/tmp裡面去,為了避免已經有同樣的檔案名稱在/tmp,加上$$
(i.e.
pid)
mv
$i
/tmp/${save_this_file}.$$
rm
-rf
$curr_dir
mkdir
-p
$curr_dir
mv
/tmp/${save_this_file}.$$
$curr_dir
done
#
屏幕執行輸出如下:
found
d1/1.txt,
save
d1/1.txt
and
remove
everything
else
under
d1/
found
d2/1.txt,
save
d2/1.txt
and
remove
everything
else
under
d2/
found
d3/1.txt,
save
d3/1.txt
and
remove
everything
else
under
d3/
found
d4/1.txt,
save
d4/1.txt
and
remove
everything
else
under
d4/
found
d5/1.txt,
save
d5/1.txt
and
remove
everything
else
under
d5/
#
復驗實驗環境:
$
ls
-l
d?/*
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
d1/1.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
d2/1.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
d3/1.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
d4/1.txt
-rw-r--r--
1
wenlee
comm
0
dec
22
10:35
d5/1.txt
ok?
thanks!

『伍』 linux下面如何遍歷目錄獲取文件

遍歷啥意思,獲取啥意思,就是全弄走么,
這個可以find 和tar組合,都提取的話,tar -czvf 備份.tgz 要提取的文件,
要只找幾個文件,可以先find,然後加入打包,注意壓縮的話就不能追加入包了。
find 位置 找啥 --exec tar -rvf 備份.tar {} \;

『陸』 在linux shell(bash)編程中,如何通過遞歸方式遍歷文件

我想這個好像沒有專門的命令的
一般都是通過編程來實現的,可以通過遞歸方式來遍歷目錄,然後得到文件數。

『柒』 linux下遍歷讀取所有子目錄里的特定文件,並改名復制到別的目錄

find . -name a.txt -exec mv {} b.txt \; 其中find後面的"."表示從當前目錄開始查找(含子目錄),注意最後的「\;"是需要的。

『捌』 linux shell 遍歷文件夾 並將結果保存 到變數

#!/bin/bash
(($#<1))&&echo"paramiszero!"&&exit1
[!-d$1]&&echo"$1notpath"&&exit1
dir=$1
dir_p="$dirDirectory:"
cd$dir
dir=`pwd`
foriin`ls$dir`
do
if[-d$i];then
/tmp/sh/dir_file$i#我的腳本文件在/tmp/sh中,需要改一下這里
else
dir_p="$dir_pFile$i"
fi
done
cd..
echo$dir_p


實驗結果:

[[email protected] sh]# ./dir_file /tmp/python/

python_2 Directory : File 1.log File 2.log

python_3 Directory : File 3.log

/tmp/python/ Directory : File p File t.py File y.py


這樣應該可以吧,試試看

『玖』 Linux下怎樣遍歷整個目錄文件

linux中有相關的API函數,可以讀取目錄中所有的文件名字,以及時間屬性信息,你把這些信息讀出來,利用各種排序演算法排序就可以了

『拾』 linux下遍歷文件並插入到oracle資料庫,怎麼做

#!/bin/bash

for num in `cat aaa/*.txt`; do
sqlplus 'user01/123456' << EOF
insert into table1(id) values($num);
quit;
EOF
done
exit 0;

熱點內容
家人訪問 發布:2022-08-08 09:13:30 瀏覽:202
維氏拍賣演算法 發布:2022-08-08 09:12:31 瀏覽:198
新股額度演算法 發布:2022-08-08 09:09:11 瀏覽:815
如何破密碼手機 發布:2022-08-08 09:07:53 瀏覽:361
關系型資料庫的分類 發布:2022-08-08 09:07:49 瀏覽:774
vbs腳本手冊 發布:2022-08-08 09:07:37 瀏覽:483
證件或密碼錯誤是什麼意思 發布:2022-08-08 09:06:56 瀏覽:878
部落沖突腳本輔助下載 發布:2022-08-08 09:06:52 瀏覽:235
三加二編程 發布:2022-08-08 09:05:01 瀏覽:629
阿里雲伺服器ip多久更改 發布:2022-08-08 09:04:55 瀏覽:428