python讀取表格生成對應(yīng)文件

# coding=utf-8
import os
import sys
import xlrd
import codecs
import collections
import json
import io

# 
def genLangJson (fileName, nameIdx, idx):
    data = xlrd.open_workbook(fileName)
    table = data.sheets()[0]
    rowNum = table.nrows                  # 行數(shù)
    colNum = table.ncols                  # 列數(shù)

    if colNum <= idx:
        return False
    
    lang = ''                                       #語言代號 從第0行讀取
    data = {}
    for lineIdx in range(rowNum):
        name  = table.cell(lineIdx,nameIdx).value   #第N行 的 key 值
        value = table.cell(lineIdx,idx).value       #第N行 的 對應(yīng)翻譯 
        if not name.strip():
            # 跳過沒有對應(yīng)token字體的文本
            continue

        if not value.strip():
            # 文本缺失
            print("For " + lang + "in line " + str(lineIdx+1) + "miss")
            continue

        if lineIdx == 0:
            # 首行
            lang = value                     # 語言代號en_us es_es
        else:
            # print("%s" % (value) )
            data[name] = value

    lang = lang#.encode("utf-8")
    print("lang:%s" % lang)

    # 文件結(jié)束翻斟,寫文件
    curPath  = os.path.dirname(os.path.abspath(__file__))
    jsonPath = os.path.join(curPath, "res", "lang1", lang, "text.txt")
    # jsonPath = curPath + "\\" + lang + "\\text.txt"
    
    # 生成文件夾
    dirname = os.path.dirname(jsonPath)
    if not os.path.exists(dirname):
        os.makedirs(dirname)

    with io.open(jsonPath, 'w', encoding='utf-8') as f:
        f.write(json.dumps(data, ensure_ascii=False, indent=4, sort_keys=True))

    return True

# 生成json翻譯文本
def makeJsonFile(fileName, tokenIdx, startIdx):
    idx = startIdx
    while (1):
        bret = genLangJson(fileName, tokenIdx, idx)      # 從左往右拆内,一列列讀取
        if (bret == False):
            break
        idx += 1

if __name__ == '__main__':

    # 自動查找excel文檔- 
    curPath = os.path.dirname(os.path.abspath(__file__))
    xlsFile = curPath + '\\lang.xlsx'

    print("xlsx file:%s" % xlsFile)

    # 各列位置(從0開始)
    tokenIdx = 0  # Token所在的列   key 值
    startIdx = 1  # 正式語言列
    # fntIdx = 3    # 字體列ttf_xx

    makeJsonFile(xlsFile, tokenIdx, startIdx)


?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市先鱼,隨后出現(xiàn)的幾起案子刊苍,更是在濱河造成了極大的恐慌茅姜,老刑警劉巖棘街,帶你破解...
    沈念sama閱讀 211,948評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件刮吧,死亡現(xiàn)場離奇詭異槐秧,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評論 3 385
  • 文/潘曉璐 我一進店門崔泵,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蚓庭,“玉大人,你說我怎么就攤上這事膀懈《倜蹋” “怎么了?”我有些...
    開封第一講書人閱讀 157,490評論 0 348
  • 文/不壞的土叔 我叫張陵启搂,是天一觀的道長硼控。 經(jīng)常有香客問我,道長胳赌,這世上最難降的妖魔是什么牢撼? 我笑而不...
    開封第一講書人閱讀 56,521評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮疑苫,結(jié)果婚禮上熏版,老公的妹妹穿的比我還像新娘。我一直安慰自己捍掺,他們只是感情好撼短,可當(dāng)我...
    茶點故事閱讀 65,627評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著挺勿,像睡著了一般曲横。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上满钟,一...
    開封第一講書人閱讀 49,842評論 1 290
  • 那天胜榔,我揣著相機與錄音胳喷,去河邊找鬼。 笑死夭织,一個胖子當(dāng)著我的面吹牛吭露,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播尊惰,決...
    沈念sama閱讀 38,997評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼讲竿,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了弄屡?” 一聲冷哼從身側(cè)響起题禀,我...
    開封第一講書人閱讀 37,741評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎膀捷,沒想到半個月后迈嘹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,203評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡全庸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,534評論 2 327
  • 正文 我和宋清朗相戀三年秀仲,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片壶笼。...
    茶點故事閱讀 38,673評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡神僵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出覆劈,到底是詐尸還是另有隱情保礼,我是刑警寧澤,帶...
    沈念sama閱讀 34,339評論 4 330
  • 正文 年R本政府宣布责语,位于F島的核電站炮障,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏鹦筹。R本人自食惡果不足惜铝阐,卻給世界環(huán)境...
    茶點故事閱讀 39,955評論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望铐拐。 院中可真熱鬧徘键,春花似錦、人聲如沸遍蟋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽虚青。三九已至它呀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背纵穿。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評論 1 266
  • 我被黑心中介騙來泰國打工下隧, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人谓媒。 一個月前我還...
    沈念sama閱讀 46,394評論 2 360
  • 正文 我出身青樓淆院,卻偏偏與公主長得像,于是被迫代替她去往敵國和親句惯。 傳聞我的和親對象是個殘疾皇子土辩,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,562評論 2 349

推薦閱讀更多精彩內(nèi)容