GraphQL Clients 代码优化

2018-12-14  本文已影响0人  林慕空

小布什微笑地讲了一句很沉重的话 :“我曾经听说,人最好趁年轻的时候就去世,当然,要越晚越好……”
I once heard it said of man that the idea is to die young as late as possible

如果把这句话,年迈的程序员用Python 语言翻译一下,就是:“写代码,要越年轻越好”
单位来了一位实习生,学习能力超强,写代码飞快,让我唏嘘不已,想起19岁就名校毕业的自己。
一个程序员如何带着尊严,幽默和善良而老去( As he aged he taught us how to grow with dignity, humor and kindness)

好,言归正传,我们的经验可以代码更简洁更好复用

一、 GraphQL 创建mutation create语句 (动态表名和字段)

def mutation_create(table_name, str_sql, str_status):
    table_name_camelCase = table_name[0].lower() + table_name[1:]
    strmutation = """
        mutation{
          create%s(%s){
            status
            %s{
                %s
            }
          }
        }
        """ % (table_name, str_sql, table_name_camelCase, str_status)

    return strmutation

二、 GraphQL 批量导入数据

def import_from_api(api_url, table_name, *args):
    with urllib.request.urlopen(api_url) as url:
        data = json.loads(url.read().decode())
        for obj in data:
            str_sql = ""
            str_status = ""
            for arg in args:
                # key name must be camelCased
                argCamel = camel(arg)
                str_sql += "%s:\"%s\"," % (argCamel, obj[arg])
                str_status += argCamel + '\n'
            # create graphql sql
            strmutation = mutation_create(table_name, str_sql, str_status)
            # execute graphql
            mutation_result = mutation_graphql(strmutation)

三、 GraphQL 清空整表数据


def truncate_table(table_name):
    query_str = "all%ss" % table_name
    strquery = """
    {
      %s{
        id

      }
    }
            """ % query_str
    query_result = query_graphql(strquery)
    for data in query_result["data"][query_str]:
        data_id = int(data["id"])
        strmutation = mutation_delete_table(table_name, data_id)
        mutation_result = mutation_graphql(strmutation)
上一篇 下一篇

猜你喜欢

热点阅读