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

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

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

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python

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

pandas

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

Q&A

解決済

2回答

1208閲覧

pythonのcsvファイルを利用した範囲指定での計算

umushi

総合スコア2

CSV

CSV(Comma-Separated Values)はコンマで区切られた明白なテキスト値のリストです。もしくは、そのフォーマットでひとつ以上のリストを含むファイルを指します。

Python

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

pandas

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

0グッド

0クリップ

投稿2021/10/23 08:24

編集2021/10/23 08:26

前提・実現したいこと

pythonのcsvファイルを利用した範囲指定での計算

pythonでpandasを用いてプログラムを作っているのですが、エラーメッセージが出てしまいます。
下記のようなプログラムを作りたいと考えています。

index A B
1 1 0
2 0 0
3 1 2 (=A1+A2+A3)
4 0 1 (=A2+A3+A4)
5 0 1 (=A3+A4+A5)
. . .
. . .
. . .
1500 1 1(=A1498+A1499+A1500)

発生している問題・エラーメッセージ

TypeError: 'int' object is not subscriptable

該当のソースコード

python

1test1 = pd.read_csv("test1.csv",encoding="shift-jis",index_col = 0) 2tmp1 = [0 for i in range(len(test1))] 3 4test_l1 = test1["A"].to_list() 5for i, dat1 in enumerate(test_l1): 6 if i >= 3: 7 tmp1[i] = dat1[i] + dat1[i-1] + dat1[i-2] 8 else: 9 tmp1[i] = 0 10 11df1 = pd.read_csv("test1.csv",encoding="shift-jis",header = 0) 12df1["B"] = tmp1 13df1.to_csv("test1.csv",columns=['1', '2', '3',"4","5","A","B"],encoding="shift-jis") 14 15

試したこと

調べてみて、intを付けてみたり、別の変数で定義してみましたがうまくいきませんでした。

補足情報(FW/ツールのバージョンなど)

pythonのver3.9.6を使用しています。
よろしくお願い致します。

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

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

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

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

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

guest

回答2

0

shift を使うと簡単にできます。ご参考まで
元のcsvファイルに index 列と A 列があるとして

Python

1import pandas as pd 2 3test1 = pd.read_csv("test1.csv",encoding="shift-jis",index_col = 0) 4test1 = test1.reset_index() 5test1['X'] = test1['A'].shift(1).fillna(0).astype(int) 6test1['Y'] = test1['A'].shift(2).fillna(0).astype(int) 7test1['B'] = test1['A'] + test1['X'] + test1['Y'] 8test1.loc[0:1,'B'] = 0 9test1.to_csv("test1.csv", columns=['A','B'], index=False, encoding="shift-jis")

投稿2021/10/23 10:46

lehshell

総合スコア1156

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

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

umushi

2021/10/23 11:29

回答してくださり、ありがとうございます。 今回は現在のプログラムを改善してくださった方をベストアンサーとさせていただきました。 ありがとうございました。
guest

0

ベストアンサー

入力データの形式が不明なので間違っているかもしれませんが、dat1[i]ではなくtest_l1[i]ではないでしょうか。

test_l1が「A列の数値のリスト([1, 0, 1, 0, 0, ...])」とすると、それをfor i, dat1 in enumerate(test_l1)した結果、dat1がリストではなくintとなります。
当然、intはインデックスアクセスできないのでTypeError: 'int' object is not subscriptableとなったのではと愚推します。

投稿2021/10/23 10:23

fj68

総合スコア752

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

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

umushi

2021/10/23 11:28

回答してくださり、ありがとうございます。 おっしゃる通り、dat1[i]をtest_l1[i]に変えたところ、実現することができました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問