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

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

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

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

Q&A

解決済

1回答

4720閲覧

Pythonで変数の中に変数が入らない。

YUKI_B

総合スコア77

Python 3.x

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

Python

Pythonは、コードの読みやすさが特徴的なプログラミング言語の1つです。 強い型付け、動的型付けに対応しており、後方互換性がないバージョン2系とバージョン3系が使用されています。 商用製品の開発にも無料で使用でき、OSだけでなく仮想環境にも対応。Unicodeによる文字列操作をサポートしているため、日本語処理も標準で可能です。

0グッド

0クリップ

投稿2018/11/15 08:29

前提・実現したいこと

エネルギー消費性能計算プログラム(住宅版)のAPIを用いたプログラムを作成中です。
ですが、データの送信の際に必要な変数の中に変数を入れることができません。
対処方法をご教授いただければ幸いです。

発生している問題・エラーメッセージ

6.14
13.9
14.7
<House FileVer="1" Name="Sample" Type="Standard,Independent" TotalArea="120.08">
<Environment Region="6" />
<Zones>
<Zone Type="LDK" Area="29.81" NaturalWind="0" />
<Zone Type="Other" Area="51.34" NaturalWind="0" />
</Zones>
<Envelope HeatStorage="None" EvaluationMethod="Real" TotalEnvelopeArea="307.51" UAValue=,UA SummerHAValue=,ηAC WinterHAValue=,ηAH />
<Heating Type="NotInstalled" />
<Cooling Type="NotInstalled" />
<Ventilation Type="DuctVentilation2or3" SFP="0.3" Frequency="HalfPerHour" />
<Lighting />
</House>

E_C: None

該当のソースコード

import urllib.request import xml.etree.ElementTree as ET import openpyxl as px book = px.load_workbook('BASE.xlsx') sheet = book.active ########################################################################################## ## ここからはデータ入力 for i in range(1): UA_row = "C" + str(17 + i) ηAC_row = "D" + str(17 + i) ηAH_row = "E" + str(17 + i) UA = sheet[UA_row].value ηAC = sheet[ηAC_row].value ηAH = sheet[ηAH_row].value print(UA ) print(ηAC) print(ηAH) ########################################################################################## model = """ <House FileVer="1" Name="Sample" Type="Standard,Independent" TotalArea="120.08"> <Environment Region="6" /> <Zones> <Zone Type="LDK" Area="29.81" NaturalWind="0" /> <Zone Type="Other" Area="51.34" NaturalWind="0" /> </Zones> <Envelope HeatStorage="None" EvaluationMethod="Real" TotalEnvelopeArea="307.51" UAValue="UA" SummerHAValue="ηAC" WinterHAValue="ηAH" /> <Heating Type="NotInstalled" /> <Cooling Type="NotInstalled" /> <Ventilation Type="DuctVentilation2or3" SFP="0.3" Frequency="HalfPerHour" /> <Lighting /> </House> """ print(model) data = "<request><model>{}</model><format>NewStandard</format></request>".format(model) data = data.encode() # to bytes req = urllib.request.Request('https://house.app.lowenergy.jp/api/v1/eval', data=data) req.add_header('Content-type', 'application/xml; charset=utf-8') req.add_header('Accept', 'application/xml') res = urllib.request.urlopen(req) xml = res.read() E_C = ( "E_C: {}".format(ET.fromstring(xml).findtext('E_C'))) print(E_C) ####################################################################################### #print(sheet[A_row].value) #sheet[B_row].value = (E_C) #i += 1 book.save('BASE.xlsx')

試したこと

問題となっている箇所は53行目の

UAValue="UA" SummerHAValue="ηAC" WinterHAValue="ηAH" />

ここの箇所が変数ではなく文字として扱われているのだと思います。
変数にするために.valueをつけましたり、ダブルクォーテーション""を削除したりしたのですが
駄目でした。

補足情報(FW/ツールのバージョンなど)

APIマニュアルへのリンク
OS:Windows10,python:3.7.1
エディタ:Brackets

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

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

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

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

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

guest

回答1

0

ベストアンサー

何もしなければそうなるのは正常な動作です(たまたま変数名が文字列の中に入っただけで値が出てきたら怖いですよね)。

f-stringを使ってください。

参考:Pythonのf文字列(フォーマット済み文字列リテラル)の使い方 | note.nkmk.me

python

1UA = "hoge" 2ηAC = "fuga" 3ηAH = "piyo" 4 5model = f""" 6<House FileVer="1" Name="Sample" Type="Standard,Independent" TotalArea="120.08"> 7 <Environment Region="6" /> 8 <Zones> 9 <Zone Type="LDK" Area="29.81" NaturalWind="0" /> 10 <Zone Type="Other" Area="51.34" NaturalWind="0" /> 11 </Zones> 12 <Envelope HeatStorage="None" EvaluationMethod="Real" TotalEnvelopeArea="307.51" 13 UAValue="{UA}" SummerHAValue="{ηAC}" WinterHAValue="{ηAH}" /> 14 <Heating Type="NotInstalled" /> 15 <Cooling Type="NotInstalled" /> 16 <Ventilation Type="DuctVentilation2or3" SFP="0.3" Frequency="HalfPerHour" /> 17 <Lighting /> 18</House> 19""" 20 21print(model) 22""" => 23<House FileVer="1" Name="Sample" Type="Standard,Independent" TotalArea="120.08"> 24 <Environment Region="6" /> 25 <Zones> 26 <Zone Type="LDK" Area="29.81" NaturalWind="0" /> 27 <Zone Type="Other" Area="51.34" NaturalWind="0" /> 28 </Zones> 29 <Envelope HeatStorage="None" EvaluationMethod="Real" TotalEnvelopeArea="307.51" 30 UAValue="hoge" SummerHAValue="fuga" WinterHAValue="piyo" /> 31 <Heating Type="NotInstalled" /> 32 <Cooling Type="NotInstalled" /> 33 <Ventilation Type="DuctVentilation2or3" SFP="0.3" Frequency="HalfPerHour" /> 34 <Lighting /> 35</House> 36"""

投稿2018/11/15 08:39

hayataka2049

総合スコア30933

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

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

YUKI_B

2018/11/15 09:10

できました! >>変数名が文字列の中に入っただけで値が出てきたら怖いですよね。 なるほど >>f-stringを使ってください。 わざわざ為になるブックマークを張っていただきありがとうございます。 いろいろ参考いたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問