我们项目里某些图片资源文件地址是配置在firebase上的,这种做法降低了server开发难度,正常来讲图片资源地址应该是由server返回的,但为了便于后期更改,server就需要开发相关的管理后台,提供接口更改图片资源地址。而配置在Firebase就免去了管理后台的开发。

最近我们项目上需要大量在Firebase配置图片地址,虽然明知道这是不合理的需求,是在滥用Firebase,但面对当前项目上的实际情况也只能妥协了,Firebase上的配置结构如下图:

python怎么打印出不同目录文件的内容 python打印目录结构_图片资源


xh/xxh字段就分别对应了不同设备的图片资源地址,之前都是少量的几个图片资源,而我遇到的情况是要配置200张左右的图片地址,如果参考之前的做法,手动上传一张图片,然后在将对应的图片地址配置到Firebase上,可想而知绝对是个大的体力活。因此我就写了一个脚本,按照Firebase上的数据结构先在本地组织好图片,然后用脚本上传图片,并自动生成json文件。本地图片的结构如下图:

python怎么打印出不同目录文件的内容 python打印目录结构_Firebase_02


脚本运行完成后,后生成对应的json文件,如下图:

python怎么打印出不同目录文件的内容 python打印目录结构_Firebase_03


将生成的json复制到firebasejson文件的对应字段下,在导入回firebase即可快速完成配置.

原来半天多的工作量,缩短到了几分钟^ _ ^。

最后奉上脚本:

#!/usr/bin/env python
# -*- coding: UTF-8 -*-

import commands
import os
import json

UPLOAD_CMD = "curl -X POST https://<server-address> -F file=%s -F saveFolder=<folderName>"

'''
@author: azhengye
@summary: 本脚本根据本地的文件结构,上传图片到server后台,并且生成对应目录结构的json文件,方便firebase配置
用法:1.本地按照firebase想配置的结构,整理好本地图片
     2.将本脚本放在要上传的文件包同级目录运行
'''

def generateData(abs_path):
    # print "abs_path==%s" % abs_path
    os.chdir(abs_path)
    cmd = 'find . -name *.png'
    X = commands.getoutput(cmd).split('\n')
    data = []
    for x in X:
        data.append(x.split('/')[1:])
    # print "data==%s" % data
    d = {}
    temp = abs_path
    for path in data:
        current_level = d
        for part in path:
            if part == path[-2]:
                str = '/'
                # print 'current dir=%s' % os.getcwd()
                file1 = str.join(path)
                file = os.path.join(temp, file1)
                print "upload fie:%s" % file
                filename = path[-1]
                uploadfilename = '@' + filename
                # 文件所在的绝对路径
                file_abs_path = os.path.dirname(file)
                # 进入该目录
                os.chdir(file_abs_path)
                # print "upload path :%s" % os.getcwd()
                uploadCmd = UPLOAD_CMD % uploadfilename
                # print "uploadCmd=%s" % uploadCmd
                uploadResult = commands.getoutput(uploadCmd)
                # print "uploadResult :%s" % uploadResult
                dicdata = json.loads(uploadResult.split('\n')[-1])
                print "uploadResult url :%s" % dicdata['url']
                current_level[path[-2]] = dicdata['url']
            elif part == path[-1]:
                pass
            else:
                if part not in current_level:
                    # print 'part==%s' % part
                    current_level[part] = {}
                current_level = current_level[part]
    os.chdir(temp)
    commands.getoutput('rm data.json')
    with open('data.json', 'w') as f:
        print 'genear json----'
        json.dump(d, f)


if __name__ == '__main__':
    abs_path = os.getcwd()
    generateData(abs_path)