質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
87.20%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

解決済

PythonでcsvファイルをYamlに変換したい。

saito5940
saito5940

総合スコア47

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

1回答

0評価

0クリップ

551閲覧

投稿2022/04/03 22:16

編集2022/04/05 04:57

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ファイルの構造を見直す必要があるのでしょうか?

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

気になる質問をクリップする

クリップした質問は、後からいつでもマイページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
87.20%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問

同じタグがついた質問を見る

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。