python初学者です。
csvファイルを読み込み、Yamlファイルに変換したいとコードを書いています。
csvファイルはこんな形式です。
version:,3 services:, db:, container_name:,atcoder-stream-db image,postgres:12.1 expose,"- ""5432""" web-backend:, container_name:,atcoder-stream build, context:,./atcoder-stream dockerfile:,Dockerfile volumes:, - ./atcoder-stream・・・・ ,- ./atcoder-stream-backend/・・・ ,- ./atcoder-stream-backend/・・ ports:, ," - ""8000:8000""" depends_on:, , - db command:,"sh -c ""python /app/src/atcoder-stream-api/manage.py migrate && python" , , web-frontend:, container_name:,atcoder-stream build:, context:,./atcoder-stream dockerfil:,Dockerfile volumes:, ,- ./atcoder-stream-frontend:/app port:, ," - ""3000:3000""" command:," sh -c ""cd /app && yarn start"""
こんな感じのファイルです。これを変換すると、
想定しているのが(サンプルです)
version: "3" services: db: container_name: atcoder-stream-db image: postgres:12.1 expose: - "5432" web-backend: container_name: atcoder build: context: ./atcoder dockerfile: Dockerfile volumes: - ./atcoder-stream-backend - ./atcoder-stream-backend - ./atcoder-stream-backend/ ports: # host:container - "8000:8000" depends_on: - db command: sh -c "python /app/src/atcoder-stream-api/manage.py migrate && python /app/src/atcoder-stream-api/manage.py runserver 0.0.0.0:8000" web-frontend: container_name: atcoder-stream build: context: ./atcoder-stream dockerfile: Dockerfile volumes: - ./atcoder-stream-frontend:/app ports: # host:container - "3000:3000" command: sh -c "cd /app && yarn start"
こんなdocker-compose.ymlのような形式で出力させたいのですが、
テストで以下のようにpythonで記述しました。
import pandas as pd from pathlib import Path import yaml path = Path('keywords.csv') df = pd.read_csv(path, encoding='cp932') # print(df) # path2 = Path('data2.csv') # df.to_csv(path2, encoding='cp932', index=False) # print(df) df = pd.read_csv(path, encoding='cp932',index_col=0) with open('config.yml','w') as yaml_file: yaml.dump( df.to_dict(orient='dict'), yaml_file, sort_keys=False, )
出力結果は
'3': 'services:': .nan 'db:': .nan 'container_name:': atcoder-stream・・・ image: postgres:12.1 expose: '- "5432"' 'web-backend:': .nan ' build': .nan 'context:': ./atcoder-stream・・・ 'dockerfile:': Dockerfile 'volumes:': .nan .nan: ' - "3000:3000"' 'ports:': .nan 'depends_on:': .nan 'command:': sh -c "python /app/src/atcoder-stream-api/manage.py migrate && python 'web-frontend:': .nan 'build:': .nan 'dockerfil:': Dockerfile 'port:': .nan ' command:': ' sh -c "cd /app && yarn start"'
versionが表示されなくて3だけが出力されます。
nanが表示されています。
vscodeをよく見ると、cofig.yaml→{version}になっています。
何故文字列と認識されないのか分かりません。
keyに対してvalueが空だからnanと出力されたのだと思いますが、これを削除したいです。
ただのエクセルならnamをpandasで削除と考えたのですが、
調べてみたこと
https://stackoverflow.com/questions/46680807/csv-to-yaml-conversion-using-python-script
csvファイルの構造を見直す必要があるのでしょうか?

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2022/04/04 19:56 編集
2022/04/04 19:48
2022/04/04 19:57 編集