Created
          May 17, 2012 01:45 
        
      - 
      
- 
        Save gamame/2715560 to your computer and use it in GitHub Desktop. 
    Python Avro Data Read Write
  
        
  
    
      This file contains hidden or 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 the schema, datafile and io submodules | |
| # from avro (easy_install avro) | |
| from avro import schema, datafile, io | |
| OUTFILE_NAME = 'sample.avro' | |
| SCHEMA_STR = """{ | |
| "type": "record", | |
| "name": "sampleAvro", | |
| "namespace": "AVRO", | |
| "fields": [ | |
| { "name": "name" , "type": "string" }, | |
| { "name": "age" , "type": "int" }, | |
| { "name": "address", "type": "string" }, | |
| { "name": "value" , "type": "long" } | |
| ] | |
| }""" | |
| SCHEMA = schema.parse(SCHEMA_STR) | |
| def write_avro_file(): | |
| # Lets generate our data | |
| data = {} | |
| data['name'] = 'Foo' | |
| data['age'] = 19 | |
| data['address'] = '10, Bar Eggs Spam' | |
| data['value'] = 800 | |
| # Create a 'record' (datum) writer | |
| rec_writer = io.DatumWriter(SCHEMA) | |
| # Create a 'data file' (avro file) writer | |
| df_writer = datafile.DataFileWriter( | |
| # The file to contain | |
| # the records | |
| open(OUTFILE_NAME, 'wb'), | |
| # The 'record' (datum) writer | |
| rec_writer, | |
| # Schema, if writing a new file | |
| # (aka not 'appending') | |
| # (Schema is stored into | |
| # the file, so not needed | |
| # when you want the writer | |
| # to append instead) | |
| writers_schema = SCHEMA, | |
| # An optional codec name | |
| # for compression | |
| # ('null' for none) | |
| codec = 'deflate' | |
| ) | |
| # Write our data | |
| # (You can call append multiple times | |
| # to write more than one record, of course) | |
| df_writer.append(data) | |
| # Close to ensure writing is complete | |
| df_writer.close() | |
| def read_avro_file(): | |
| # Create a 'record' (datum) reader | |
| # You can pass an 'expected=SCHEMA' kwarg | |
| # if you want it to expect a particular | |
| # schema (Strict) | |
| rec_reader = io.DatumReader() | |
| # Create a 'data file' (avro file) reader | |
| df_reader = datafile.DataFileReader( | |
| open(OUTFILE_NAME), | |
| rec_reader | |
| ) | |
| # Read all records stored inside | |
| for record in df_reader: | |
| print record['name'], record['age'] | |
| print record['address'], record['value'] | |
| # Do whatever read-processing you wanna do | |
| # for each record here ... | |
| if __name__ == '__main__': | |
| # Write an AVRO file first | |
| write_avro_file() | |
| # Now, read it | |
| read_avro_file() | 
df_reader = datafile.DataFileReader(  open(OUTFILE_NAME),  rec_reader   ) This line is also not working in python3 you have to change it
df_reader = datafile.DataFileReader( open(OUTFILE_NAME,'rb'), rec_reader ) Thanks
i tried but it is showing error File "C:\Python37\lib\site-packages\avro\schema.py", line 340
except Exception, e:
^
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
            
Tried running this on Python 3.6; had to make some corrections on the print statements, writers_schema (shouldn't have "s") and schema.parse (should be schema.Parse). Thanks.