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

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

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

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

Python

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

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

Q&A

1回答

3052閲覧

S3にuploadしたtarファイルをLambdaで解凍するソースコードで'NoneType' object has no attributeとなる

fthk

総合スコア1

AWS Lambda

AWS Lambdaは、クラウド上でアプリを実行できるコンピューティングサービス。サーバーのプロビジョニングや管理を要せず複数のイベントに対してコードを実行します。カスタムロジック用いた他AWSサービスの拡張やAWSの規模やパフォーマンスを用いたバックエンドサービスを作成できます。

Python

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

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

0グッド

0クリップ

投稿2021/11/27 13:48

S3にtarファイルがアップロードされたらLambdaで解凍するソースコードを書いております。
下記ページを参考に作成しましたが解凍されず、CloudWatchのログを確認したところ'NoneType' object has no attribute 'read'となっていました。
https://qiita.com/kitamuratomokazu/items/2c9fe087dfdca4482788

その後調べていたところ下記のページで同じくtarを解凍を試みており、11/20追記で解決したようです。
同じ内容でソースコードを書きましたが変わらず'NoneType' object has no attribute 'read'となってしまいます。
https://teratail.com/questions/224128

Python

1##参考ソースコード 2 3import boto3 4import zipfile 5import traceback 6import os 7 8print('Loading function') 9 10s3 = boto3.resource('s3') 11s3_client = boto3.client('s3') 12 13def lambda_handler(event, context): 14 15 # Get the object from the event and show its content type 16 bucket = event['Records'][0]['s3']['bucket']['name'] 17 key = event['Records'][0]['s3']['object']['key'] 18 19 try: 20 s3_client.download_file(bucket, key, '/tmp/file.zip') 21 print('download') 22 zfile = zipfile.ZipFile('/tmp/file.zip') 23 namelist = zfile.namelist() 24 print(namelist) 25 26 for filename in namelist: 27 if not os.path.basename('/tmp/'+filename): 28 os.mkdir('/tmp/'+filename) 29 else: 30 f = open('/tmp/' + str(filename), 'wb') 31 data = zfile.read(filename) 32 f.write(data) 33 f.close() 34 for filename in namelist: 35 if '.jpg' in filename: 36 s3_client.upload_file('/tmp/'+filename, bucket, key + filename) 37 38 39 except Exception as e: 40 print(e) 41 print(traceback.format_exc()) 42

Python

1##作成したソースコード 2 3import boto3 4import tarfile 5import traceback 6import os 7 8print('Loading function') 9 10s3 = boto3.resource('s3') 11s3_client = boto3.client('s3') 12 13def lambda_handler(event, context): 14 15 # Get the object from the event and show its content type 16 bucket = event['Records'][0]['s3']['bucket']['name'] 17 key = event['Records'][0]['s3']['object']['key'] 18 19 try: 20 s3_client.download_file(bucket, key, '/tmp/file.tar') 21 print('download') 22 zfile = tarfile.TarFile('/tmp/file.tar') 23 namelist = zfile.getnames() 24 print(namelist) 25 for filename in namelist: 26 if not os.path.basename('/tmp/'+filename): 27 os.mkdir('/tmp/'+filename) 28 else: 29 f = open('/tmp/' + str(filename), 'wb') 30 data = zfile.extractfile(filename).read() 31 f.write(data) 32 f.close() 33 for filename in namelist: 34 s3_client.upload_file('/tmp/'+filename, bucket, filename) 35 36 37 except Exception as e: 38 print(e) 39 print(traceback.format_exc())

CloudWatchのログ

Loading function
START RequestId: 0d6618f0-3358-4b89-b53a-ef2ck12cdef0 Version: $LATEST
download
['sample', 'sample/test.xml']
'NoneType' object has no attribute 'read'
Traceback (most recent call last):
File "/var/task/lambda_function.py", line 28, in lambda_handler
data = zfile.extractfile(filename).read()
AttributeError: 'NoneType' object has no attribute 'read'
END RequestId: 0d6618f0-3358-4b89-b53a-ef2ck12cdef0
REPORT RequestId: 0d6618f0-3358-4b89-b53a-ef2ck12cdef0 Duration: 420.92 ms Billed Duration: 421 ms Memory Size: 128 MB Max Memory Used: 71 MB Init Duration: 384.54 ms
※sample.tarという名の圧縮ファイルをアップロードしました。中にはtest.xmlが格納されています。

ご助言いただけますと幸いです。
よろしくお願い致します。

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

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

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

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

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

guest

回答1

0

AttributeError: 'NoneType' object has no attribute 'read'

ってことは、
zfile.extractfile(filename)
の結果がNoneなんでしょうね。
そいつが何を返してるのかチェックしてみては。

投稿2021/11/28 00:17

y_waiwai

総合スコア88042

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問