
同じ行で重複した単語を削除したいです。
テキストファイル
sapporo aomori akita iwate akita yamagata
sendai miyagi hukushima miyagi akita
mito
・
・
上記のようなファイルの同じ行で重複した単語を削除し下の形にしたいです。
sapporo aomori akita iwate yamagata
sendai miyagi hukushima akita
mito
・
・
open(FILE1, "<xxx.txt") || die "File1 Open Error! \n";
open(OUT, ">zzz.txt") || die "OUT Open Error! \n";
$string1 = <FILE1>;
my @array = split(/\t/,"$string1");
my %count;
@array = grep {!$count{$_}++}@array;
foreach my $element (@array) {
print OUT "$element\t";
}
close(FILE1);
close(OUT);
このプログラムを実行すれば初めの一行は重複した単語を削除できるのですがそこで終了してしまいます。2行目、3行目・・といったように複数行に対して重複した単語を削除するためにはどのようにすればいいのですか。宜しくお願いします。
No.2ベストアンサー
- 回答日時:
>$string1 = <FILE1>;
これは配列で受け取ってないので、入力ファイルから1行だけ取得する処理です。
なので全行を読み込むのであれば、No.1さんの言うとおり、ループさせる必要があります。
ループの書き方ですがファイルハンドルをwhileでループさせるか、一度配列に落としてforeachでループさせるかがベタではないかと。配列に落とすんならこんな感じですかね…。
---
my @data = <FILE1>;
chomp @data;
foreach my $line (@data) {
my @array = split(/\t/, $line);
my %count;
@array = grep {!$count{$_}++}@array;
foreach my $element (@array) {
print OUT "$element\t";
}
print OUT "\n";
}
---
改行を削除しないと整形したファイルの先頭に\tがつくんで、とりあえずchompして、レコードの最後に改行付けてます。
splitで文字列を分割してリストにした後、どのようにループさせれば
良いかを考えてしまい、悪戦苦闘していました(> <)
chompの使い方含め、大変勉強になりました。有難うございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- CGI htmlからパラメータで、cgiに渡したい。 1 2023/02/06 16:15
- PHP PHPの構文で間違えが分からない 5 2022/07/11 16:38
- C言語・C++・C# c言語の問題の説明、各所ごとに 5 2023/07/26 11:03
- Excel(エクセル) 表に書いてある単語を1つの行に重複させないで書き出したい。 複数の列行にそれぞれ職種が入力されている 6 2022/05/25 04:49
- PHP SQLとPHPの連結方法がわからないのでアドバイスお願い致します 1 2022/07/12 12:16
- Visual Basic(VBA) 3つの条件を指定してVBAで行を削除したい 条件1:分類1が重複 条件2:分類2が重複 条件3:個数 6 2022/06/24 11:07
- Perl perlのflock関数でロックをかけたままopen関数で何度もファイルを開きなおすことはできますか 3 2023/05/01 22:25
- Visual Basic(VBA) エクセルのマクロについて教えてください。 4 2023/03/02 08:40
- Visual Basic(VBA) エクセルのマクロについて教えてください。 2 2023/03/12 10:10
- Visual Basic(VBA) エクセルのマクロについて教えてください。 1 2022/10/04 10:48
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
visual basic 2015で文字列の1...
-
桁数指定と四捨五入
-
Escキーを押すと、中断する時と...
-
範囲指定したセルを1つずつ飛...
-
UWSCの終了の仕方
-
エクセルVBAでTransposeの不思議
-
VBAでの一時停止と再開の方法
-
エクセルの当番表を作っていま...
-
DoEventsが必要な理由について
-
画面を強制的に再描画させる方法
-
VBAのautofilter、criteriaの配...
-
vb.netです。2次元配列の要素を...
-
素数の個数を求めるプログラミング
-
vbscriptでIE自動入力(途中で...
-
文字列を変数名として扱う方法
-
UWSCのスクリプトで行き詰って...
-
vb.netからエクセル関数書き込み
-
DataGridViewに配列の値を表示...
-
VBAで3秒だけ時間を止めたい
-
ExcelVBAで、index、match関数...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
perlで2つの配列を比較する方...
-
DBIを使ってのデータの取り出し...
-
perlでファイルの拡張子を除い...
-
データベースから取得したデー...
-
組み合わせを作るアルゴリズム
-
正規表現に関する質問
-
ソート時同じ値がある場合、表...
-
アルファベットn文字の組み合わ...
-
桁数指定と四捨五入
-
配列の操作に関して
-
QNo.3258883データベースから取...
-
perlでの、ファイル読み込みに...
-
二桁の数字からなる配列数10...
-
visual basic 2015で文字列の1...
-
配列に入った変数を二度使いたい
-
配列やハッシュで中身が同じか...
-
grep関数を用いた複数行からの抽出
-
UWSCの終了の仕方
-
画面を強制的に再描画させる方法
-
範囲指定したセルを1つずつ飛...
おすすめ情報