python 按目录结构上传文件

所以我告诉你们,凡你们祷告祈求的,无论是甚麽,只要信是得着的,就必得着。----马可福音11:24

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

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


在这里插入图片描述

xh/xxh字段就分别对应了不同设备的图片资源地址,之前都是少量的几个图片资源,而我遇到的情况是要配置200张左右的图片地址,如果参考之前的做法,手动上传一张图片,然后在将对应的图片地址配置到Firebase上,可想而知绝对是个大的体力活。

因此我就写了一个脚本,按照Firebase上的数据结构先在本地组织好图片,然后用脚本上传图片,并自动生成json文件。本地图片的结构如下图:


在这里插入图片描述

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


在这里插入图片描述

将生成的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)
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • feisky云计算、虚拟化与Linux技术笔记posts - 1014, comments - 298, trac...
    不排版阅读 3,908评论 0 5
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 11,138评论 1 32
  • 第一部分 HTML&CSS整理答案 1. 什么是HTML5? 答:HTML5是最新的HTML标准。 注意:讲述HT...
    kismetajun阅读 27,670评论 1 45
  • 没什么事研究了一下自定义ViewController切换动画,主要就是主ViewController实现UIVie...
    jy__Lu阅读 723评论 0 2
  • 我们昨天晚上我们去星河玩飞机,飞机是泡沫的但是飞在天上的时间很久,我们在路上的时候在玩抓人,路上东跑西跑特...
    王卓函阅读 233评论 0 0