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

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

新規登録して質問してみよう
ただいま回答率
85.35%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

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

Q&A

解決済

1回答

822閲覧

Python MySQLへの書き込みで分からないことがあります

person

総合スコア224

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Python 3.x

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

0グッド

1クリップ

投稿2020/02/18 05:30

編集2020/02/18 07:51

MySQLにあるデータを抽出します。

MYSQLのデータをPythonによってCSVへ出力すると、

aaa,bbb,ccc,ddd,eee,-,-,- fff,ggg,hhh,-,-,-,-,- iii,-,-,-,-,-,-,-

となります。(データベースにはすべてTEXT型で上記のように保存しています。)

実際にこのようなデータがデータベースにはあるのですが、これをpythonで取得して、pythonからCSV出力する際に、ハイフンの部分を出力しないようにしたいです(ハイフンの列は右寄せではあるが、上記のようにハイフンの列数は不明)。

このときに

aaa,bbb,ccc,ddd,eee fff,ggg,hhh iii

と出力するにはどうすればいいでしょうか?

下のコードの

# ■ ■ ■ ■ ■

の部分で、別でリストを作ったりする必要が出てきてしまうのでしょうか?

Python

1import pymysql.cursors 2import csv 3 4#ここで取得しました(省略) 5 6#タプル→リスト 7result_list = [] 8tmp = [] 9for i in range(len(result_tuple)): 10 tmp = result_tuple[i] 11 result_list.append([tmp[0], tmp[1],tmp[2], tmp[3], tmp[4], tmp[5], tmp[6], tmp[7]]) 12 13sql_data = result_list 14 15#CSV出力 16with open(path_tmp + "/" + full_filename, "w") as csvfile: 17 writer = csv.writer(csvfile, lineterminator="\r\n") 18 for i in range(len(sql_data)): 19 if sql_data[i][0] == "10": 20 sql_data[i][1] = sql_data[i][1].replace("-", "/") # ■ ■ ■ ■ ■ 21 writer.writerow(sql_data[i]) 22

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

いったん-を除いたリストを作り、それを出力するとよいかと思います。

Python

1from io import StringIO 2import csv 3 4s = """aaa,bbb,ccc,ddd,eee,-,-,- 5fff,ggg,hhh,-,-,-,-,- 6iii,-,-,-,-,-,-,-""" 7result_tuple = [(l.split(',')) for l in s.split('\n')] 8 9lines = [[e for e in t if e != '-'] for t in result_tuple] 10print(lines) # [['aaa', 'bbb', 'ccc', 'ddd', 'eee'], ['fff', 'ggg', 'hhh'], ['iii']] 11 12with open('res.csv', 'w', newline='') as f: 13 writer = csv.writer(f) 14 for line in lines: 15 writer.writerow(line) 16#aaa,bbb,ccc,ddd,eee 17#fff,ggg,hhh 18#iii

投稿2020/02/18 11:17

編集2020/02/18 11:18
can110

総合スコア38341

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問