実現したいこと
Linuxで文字コードがUTF-8のファイルに「¥」円記号(文字コード 0xC2A5)をスマートに検索して見つけ出す方法を知りたい。
Linuxでsedコマンドが、utf-8の文字コードのファイルで正しく動かないようだ
で、コマンドの
sed 's/\..*//'
がうまく動かない原因が、バックスラッシュだと思っていた文字が実は円記号「¥」であり、円記号とバックスラッシュは区別されるためだったので、簡単な方法でUTF-8の文字コードのファイル中に含まれる円記号を、例えば円記号の文字コード「0xC2A5」を指定などするして見つけ出したい。
発生している問題・分からないこと
UTF-8コード表では「¥」記号は「0xC2A5」でバックスラッシュとは違う文字なのだが、コンソール画面ではバックスラッシュ文字のように表示されており、円記号とバックスラッシュを見た目で、区別することは難しい。
UTF-8コード表
od -tx1a <ファイル名>
というコマンドである程度見やすくなるが、c2a5 の文字列をもっと簡単に見つけたい。
該当のソースコード
特になし
試したこと・調べたこと
上記の詳細・結果
文字コードを指定して、円記号を検索する方法、または他の良い方法が見つけられなかった。
補足
使用しているシェル
[tada@linux shscript]$ echo $SHELL
/bin/bash
OSのバージョン
[tada@linux shscript]$ cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
ローカライゼーション系の環境変数
[tada@linux shscript]$ locale
LANG=en_US.UTF-8
LC_CTYPE="en_US.UTF-8"
LC_NUMERIC="en_US.UTF-8"
LC_TIME="en_US.UTF-8"
LC_COLLATE="en_US.UTF-8"
LC_MONETARY="en_US.UTF-8"
LC_MESSAGES="en_US.UTF-8"
LC_PAPER="en_US.UTF-8"
LC_NAME="en_US.UTF-8"
LC_ADDRESS="en_US.UTF-8"
LC_TELEPHONE="en_US.UTF-8"
LC_MEASUREMENT="en_US.UTF-8"
LC_IDENTIFICATION="en_US.UTF-8"
LC_ALL=
0 コメント