質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

Q&A

解決済

2回答

441閲覧

pandasで()を削除したい

ueshima900

総合スコア27

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

pandas

Pandasは、PythonでRにおけるデータフレームに似た型を持たせることができるライブラリです。 行列計算の負担が大幅に軽減されるため、Rで行っていた集計作業をPythonでも比較的簡単に行えます。 データ構造を変更したりデータ分析したりするときにも便利です。

0グッド

0クリップ

投稿2020/02/21 08:23

以下のcsvFileで(文字)を消して日付に変更したい

理想

2020/02/09 06:33,
2020/02/10 07:00,
2020/02/10 15:31,
...

csvfile

時刻,
2020/02/09(日) 06:33,
2020/02/10(月) 07:00,
2020/02/10(水) 15:31,
...

試したこと

df['時刻'].str.replace("[([", "")
2020/02/09日) 06:33
上記のように初めの(は消えましたが、(日)などで消すことができませんでした。

正規表現がいまいちわからないので、もしよろしければ
お力借りれませんでしょうか?

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ベストアンサー

シンプルに処理するなら、以下で。

python

1df["時刻"] = df["時刻"].str.replace(r"(.)", "")

まずr""のような先頭にrのついたPythonの文字列リテラルはraw-strings(r文字列)と呼ばれるもので、Pythonの文字列で通常必要なエスケープを不要にしてくれます。r"hoge\fuga" == "hoge\fuga" ということ。()(,)が正規表現で意味を持つ文字であるため、正規表現として解釈されないためのエスケープを付与しています。.は任意の一文字にマッチです。(笑)とかにもマッチするので気をつけてください。逆に(火曜)があったらそれは拾えません。

確認用。

python

1>>> import pandas as pd 2>>> df = pd.DataFrame({"時刻":["2020/02/09(日) 06:33", "2020/02/10(月) 07:00", "2020/02/10(水) 15:31"]}) 3>>> df["時刻"].str.replace(r"(.)", "") 40 2020/02/09 06:33 51 2020/02/10 07:00 62 2020/02/10 15:31 7Name: 時刻, dtype: object

投稿2020/02/21 20:34

hayataka2049

総合スコア30935

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

ueshima900

2020/02/29 00:58

ご回答いただきありがとうございます。 正規表現の記入方法など理解が深まりました。
guest

0

こんにちは

以下でどうでしょう?

python3

1df.loc[:, '時刻'] = df['時刻'].map(lambda s: re.sub(r'(.)', '', s))

 

追記1

正規表現を使う別の方法として、以下でもよいかと思います。

python3

1before = r'^(\d{4}/\d{2}/\d{2})([日月火水木金土])\s+(\d{2}:\d{2})$' 2after = r'\1 \2' 3 4df.replace({'時刻': before}, {'時刻': after}, regex=True, inplace=True)

 

追記2

所与のデータフレームの時刻列には、日時として満たすべき形式の文字列が入っていることを前提とすれば、追記1のコードの before は、以下のような簡単なものでも事足ります。

python3

1before = r'^(.+)(.)(.+)$'

この場合、after は以下のように \1\2 をスペースなしでつなげます。

python3

1after = r'\1\2'

投稿2020/02/21 08:41

編集2020/02/21 14:54
jun68ykt

総合スコア9058

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問