CSVの欠損値を補填したい
CSV
1a,b 210:40,200.0 310:50, 411:00,250.0
上記のCSVの例の場合、下記のCSVのように欠損値の箇所は3行目の10:50の横になりますがそこの箇所に前の値、つまり200.0を書き込みたいと思っています。
CSV
1a,b 210:40,200.0 310:50,200.0 411:00,250.0
ただ下記のプログラムで実行すると、
Python
1from selenium import webdriver 2import time 3import csv 4import threading 5import pandas as pd 6import datetime 7import numpy as np 8 9 10# csbリストの各列の行数の確認 11df_a = pd.read_csv("datefile_test2.csv", header=0, encoding='utf-8') 12df_a.fillna(method = 'ffill') 13 14print(df_a)
fillnaを使い、前の値を書き込もうとすると下記の結果となります。
a b 0 10:40 200.0 1 10:50 NaN 2 11:00 250.0
欠損値NaNのままとなり、上手くできません。どうしたらいいでしょうか。
試したこと
Python
1 2from selenium import webdriver 3import time 4import csv 5import threading 6import pandas as pd 7import datetime 8import numpy as np 9 10 11df_a = pd.read_csv("datefile_test2.csv", header=0, encoding='utf-8') 12df_a.fillna(method = 'ffill') 13 14#ここで保存 15df_a.to_csv("datefile_test2.csv", index=False) 16 17df_a = pd.read_csv("datefile_test2.csv", header=0, encoding='utf-8') 18 19print(df_a)
上記のプログラムで一旦保存して出力しています
a b 0 10:40 200.0 1 10:50 NaN 2 11:00 250.0
ただやはり上記の結果となり思うようにできません
補足情報(FW/ツールのバージョンなど)
Windows8.1
Python3.6.3
Pycharm
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/01/31 15:31