Created
March 13, 2018 21:45
-
-
Save sbealer/3ca1de4c58fba072b50fd65d6f361476 to your computer and use it in GitHub Desktop.
Ship a compressed (gzip) csv to S3. Write to your compressed file with csv writer in one step. Python 3
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import io | |
import gzip | |
import csv | |
import boto3 | |
import os | |
destination_bucket = 'your-directory' | |
destination_directory = 'your/directory/' | |
destination_filename = 'text.csv.gz' | |
your_access_key = os.environ['AWS_ACCESS_KEY'] | |
your_secret_key = os.environ['AWS_SECRET_KEY'] | |
data = [['col1','col2','col3','col4'], | |
['data','data','three','four'], | |
['data','data','three','four'], | |
['data','data','three','four']] | |
mem_file = io.BytesIO() | |
with gzip.GzipFile(fileobj=mem_file,mode='w') as gz: | |
buff = io.StringIO() | |
writer = csv.writer(buff) | |
writer.writerows(data) | |
print("Writing data to gzipped file.") | |
gz.write(buff.getvalue().encode()) | |
print("Data written") | |
gz.close() | |
mem_file.seek(0) | |
s3 = boto3.client('s3',aws_access_key_id=your_access_key,aws_secret_access_key=your_secret_key) | |
print("Sending to S3") | |
s3.upload_fileobj(Fileobj=mem_file, Bucket=destination_bucket, Key=destination_directory+destination_filename) | |
print("Sent") |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment