更新hive元数据-python代码

因为之前平台部署的hive下的元数据是放在mysql中的,而mysql由设置了为了拉丁文,导致元数据都是乱码的。

于是开始了更新计划,办法就是用svn中的建表语句,提取出来写到元数据的mysql下,然后在mysql里进行更新(还好建表语句的备注都写得比较详细)

方案就是:

1、用python实现文件遍历,找到sql扩展名的文件。

2、找出对应的数据库,表名,字段名,备注并写出为文件(或者直接通过python写到mysql)

3、把结果文件写入到hive的元数据库中

4、在hive的元数据库中进行匹配

遇到的问题:

1、python的文件编码问题(解决办法是先获取文件的编码先成参数,然后再以该编码形式打开文件)

2、安装mysql-python(mac的电脑需要先安装xcode)

3、python写入到mysql的乱码问题(设置mysql的编码及在python  connect到mysql的时候加上编码)

附上python代码。另外mac下用python连接mysql的文章在另一篇。


#!/usr/bin/python

#-*- coding: utf-8 -*-

import sys

import os

import re

import chardet

import codecs

import MySQLdb

path="/Users/zhangyupeng/SVN/10_UAT_DEPLOY/SCFS/"

#connect the database

db = MySQLdb.connect(host="localhost" , user="root" , passwd="XXXX" , db="test_python" , charset="utf8")

cursor=db.cursor()

for i in os.walk(path):

file= str(i[2]).strip().split(',')

for j in file:

if j.lower().find('.sql')>0:

#take the SVN file path

#kill the symbol

j=j.strip().replace('[','').replace(']','').replace('\'','',10).replace('/','')

path=str(i[0])+'/'+j

#pass the udf & 10_TEMP & FXDS

if path.find('10_TEMP')>0:

continue;

if path.find('UDF')>0:

continue

if path.find('FXDS')>0:

continue;

#open the SVN file and take the info

with open(path,"rb") as f:

#open the file with code

data = f.read()

code=(chardet.detect(data))

code_p=str(code)[str(code)[:-2].rfind('\'')+1:].replace('\'','').replace('}','').replace(': ','')

mysql=codecs.open(path, 'rb',code_p)

#take the infomation

for line in mysql:

p1=line.lower().strip().encode('utf-8')

a3=''

a4=''

p=str(p1)

#kill the comment

if str(p)[0:2]=='--':

continue;

#search the database & table

if str(p).find('create')>=0  and str(p).find('table')>=0:

#take the database

aa1=str(p)[0:str(p).find('.')]

a1=aa1[aa1.rfind(' ')+1:]

#take the table

a2=str(p)[str(p).rfind('.')+1:].replace('(','')

#search the field & comment

if str(p).find('comment')>0:

#take the field

a3=str(p)[:str(p).find(' ')]

#take the comment

a4=str(p)[str(p).rfind('comment',10)+8:].replace(' ','',20).replace('\'','',10).replace(',','',20)

#kill the null

if a3=='' or a3==')':

continue;

#print a1+','+a2+','+a3+','+a4

#print 'database:',a1,'|','table:',a2,'|','field:',a3,'|','comment:',a4

cursor.execute('insert into svn_field_comment_test values("%s", "%s", "%s", "%s")' % \

(a1,a2,a3,a4))

db.commit()

db.close

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容