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

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

新規登録して質問してみよう
ただいま回答率
85.50%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

Python

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

Q&A

解決済

1回答

3278閲覧

pythonでフォルダ内に複数あるExcelファイルを読み取って.txtで出力したい。

colorful_39

総合スコア20

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

Python

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

0グッド

0クリップ

投稿2020/04/03 07:45

Excelで伝票を作っています。
pythonを使って少しでも楽できなかと悪戦苦闘しております。

今回は、Excelファイル内の「伝票番号」「会社名」を抜き出した一覧を
.txtで作りたいと思います。

目標

フォルダ
ファイルA
ファイルB
ファイルC

.txt
No.001 〇〇会社
No.002 ××会社
No.003 ××会社

できること

・以前にExcelファイルをopenpyxlで扱ったことがあるので
ファイル指定、シート指定、セル指定して値を取得はできます。

import openpyxl

ep = 'C:\Users\test\0000.xlsx'
wb = openpyxl.load_workbook(filename=ep)

sheet2 = wb['1111']

No = sheet2['G47'].value
client = sheet2['C47'].value

・globを使ってフォルダ内のExcelファイルを取得もできます。

import glob

files=glob.glob(r'C:\Users\test*.xlsx')

for file in files:
ここから先がわかりません。

できないこと

上記の二つを組み合わることがまずできていません。
あと、一覧を取得できたとして.txtにして書き出す
方法がわかりません。

懇願

説明が長くなりました。
もっといい方法もあると思うのですが
どなたかご教示願えませんでしょうか?
よろしくお願いします。

環境

python 3.x windows10

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

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

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

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

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

guest

回答1

0

ベストアンサー

python

1import glob 2import openpyxl 3 4#ここでxlsxファイルのパスがリスト化される 5files = glob.glob(r'C:\Users\test\*.xlsx') 6#print(files)して確認してみてください。 7#パスがリスト化され出力れると思います。 8 9 10#リストからファイルを一つずつ取り出して処理を行う 11for file in files: 12 #print(file)して確認してみてください。 13 #一つずつファイルのパスがprintされると思います。 14 15 #ここに一つずつ取り出したファイルに対しやりたい処理を書いていきます。 16 wb = openpyxl.load_workbook(filename=file) 17 sheet2 = wb['1111'] 18 No = sheet2['G47'].value 19 client = sheet2['C47'].value 20

text保存したいという事でしたが、各データを各textファイルに保存したいのか
それとも複数のデータを一つのtextファイルにまとめて保存したいのかがわからない為
正しく導く事が出来ませんが、ファイルへの保存の仕方は下記となります。

python

1 #textへの保存の処理 2 f = open('保存したいファイル名', 'w') 3 f.writelines(入力したい値) 4 f.close()

データを各textファイルに保存したいという事であればfor文の中に
複数のデータを一つのtextファイルにまとめて保存したいということであれば
for文を抜けた後に記述してあげてください。

###追記

python

1import openpyxl 2import glob 3 4 5files = glob.glob(r'C:\Users\a\Desktop\test\新しいフォルダー\*xlsx') 6#for文で取り出した値を入れておく為の辞書を用意しておく 7client_dict = {} 8for file in files: 9 wb = openpyxl.load_workbook(file) 10 num = wb['1111']['G74'].value 11 client = wb['1111']['C74'].value 12 client_dict[num] = client 13 14#textファイルをここで操作していく 15#textファイルが存在しない場合には自動で生成される。存在している場合にはそのまま追記される 16with open('ファイル名.txt', 'w', newline='\n') as f: 17 #ループ処理で辞書からkeyとvalueを取り出し文末に改行を入れて追記し保存する処理 18 for k,v in client_dict.items(): 19 f.write('No.{} {}\n'.format(k, v)) 20

投稿2020/04/03 08:10

編集2020/04/03 11:47
nto

総合スコア1438

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

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

colorful_39

2020/04/03 09:54

ご返答ありがとうございます。 ご指摘の件は「複数のデータを一つのtextファイルにまとめて保存したい」です。 前提条件の確認 「フォルダ内に、excelファイルが3つ。」 for file in files: までは出来ました。print(file)で確認し、3つの名前が出ました。 ですが、 wb = openpyxl.load_workbook(filename=file) sheet2 = wb['1111'] No = sheet2['G47'].value の時点で値が1つになってしまいました。 何が問題なのでしょうか?
nto

2020/04/03 10:51 編集

質問内容と、記載されていたコードを見るに 各Excelファイルには必ず1111というシート名のシートがあり それぞれのシート1111のG47に伝票番号、C47に企業名が入っているという認識であっていますか? これが正しければ wb = openpyxl.load_workbook(file) num = wb['1111']['G47'].value client = wb['1111']['C47'].value で取り出す事ができるとおもいます。 print(num,client)で出力ができるか確かめてみてください。
colorful_39

2020/04/03 11:46

説明不足を理解力で補って頂き恐縮です。その認識であっています。 ですが、頂いたコードを試しましたら 何故か3番目のファイルの値のみ、取得でき 1~2番目のファイルの値は、表示されませんでした。 ムムム
colorful_39

2020/04/03 11:50

すみません!できました! for文の中に続けてprintも書く必要があったのを忘れていました。 必要な値の取得はできたので、txt出力に移ります。
nto

2020/04/03 11:53

恐らくそうかと思いました。 txt保存のやり方も追記しておりますのでお確かめください。
colorful_39

2020/04/03 12:21

何から何までありがとうございます。 追記拝見させて頂きました。 client_dict[num] = client がエラーになります。 「client_dict[num] = client  NameError: name 'client_dict' is not defined」 txtファイルは出来ます。ファイル名も付きます。 ですが、開くと真っ白です。すみません。
colorful_39

2020/04/03 17:26

少々方法は違いましたが、自己解決できました。 順番を間違っていました。 ご返答有難うございました。 import glob import openpyxl files=glob.glob(r'C:\Users\test\*.xlsx') path_w = 'C:\Users\test\test.txt' with open(path_w, 'w') as f: for file in files: wb = openpyxl.load_workbook(file) A = wb['Sheet2']["G47"].value B = wb['Sheet2']['C47'].value D = wb['Sheet2']['A49'].value f.write(f"{A},{B},{C}\n")
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問