如何导入csv文件使用python脚本驻留在hdfs到mysql数据库

时间:2014-11-10 10:40:58

标签: python mysql hadoop hdfs oozie

我有一个用例,在聚合后(使用map-reduce),会生成一个csv文件。现在,我想将这个驻留在hdfs上的csv文件直接导入mysql数据库。 我写了这段代码: -

#!/usr/bin/python
import subprocess
import sys
import csv
import MySQLdb
mydb = MySQLdb.connect(host='localhost',
    user='root',
    passwd='',
    db='test')
cursor = mydb.cursor()

def main():
    #csv_data = csv.reader(file(path/to/local/testcsv.csv))
    csv_data = subprocess.Popen(["hadoop", "fs", "-cat", 'path/to/hdfs/testcsv.csv'], stdout=subprocess.PIPE)
    #for row in csv_data
    for row in csv_data.stdout:
        print row
        cursor.execute('INSERT INTO testcsv(names, \
          classes, mark )' \
          'VALUES("%s", "%s", "%s")', 
          row)
    mydb.commit()
    mydb.close()
if __name__ == "__main__":
    main()
#close the connection to the database.
print "Done"

testcsv.csv包含三个字段名称,类和标记。我在mysql中创建了testcsv表,并尝试使用oozie工作流导入。从本地文件系统而不是hdfs导入csv时,我的oozie工作流运行正常(显示在注释行中)。 运行此代码不会将数据导入mysql。 我做错了吗?

0 个答案:

没有答案