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

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

ただいまの
回答率

88.92%

(python,xlwings) xlwingsでexcelから「ユーザー定義」の値(時刻)を、そのままの形式で取得したいです

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 291

giseta

score 1

前提・実現したいこと

・python3.x環境です。
・Excelからpythonに時刻情報(h:mm:ss)を渡したいです。
・python側では列単位で取得すべくpandasのSeriesで受け取り、dataframeに格納します。
(dataframeについての考え方が間違っていたら、併せてご指摘いただけると大変助かります。)

(ここに質問の内容を詳しく書いてください。)
書式が「ユーザー定義(h:mm:ss)」で記載されているセルをxlwingsで取得すると、値が「文字列」として変換されてしまいます。
例「11:21:00」→「0.472917」

h:mm:ss のままで取得する方法をご教示ください。

該当のソースコード

・時刻がA列50行目まで記入されていることを想定しています。

import pandas as pd
import xlwings as xw

df = pd.DataFrame(columns=["hoge1","hoge2"])
df["hoge1"] = value

# dfのhoge1列にh:mm:ss形式で格納したいです
print(df)

# (1)「h:mm:ss」と表示されます
print(xw.range((1,1),(50,1)).number_format)

# (2)コンバーター?で変換されているのかな、と思い以下も試すも変化なし
# (すみません、あまり理解できておらず、おまじない感覚です。)
print(xw.range((1,1),(50,1)).options(convert=None,format="%H:%M:%S").value)

試したこと

・コメント(1)では、h:mm:ssと認識されているのに対し、.valueで値を見ると0.xxxx..となるのがよくわからないです。。
・コメント(2)では、下記リンクを参照し、書式をいじる方法が何かないか調べた際のおまじないです。
結果として変化がなく、うまくいきませんでした。
https://qiita.com/m5knt/items/a71faf6ff256f1d1ae5f
・excel上で該当セルの書式を「文字列」にすると、0.xxxx..形式になります。
・excelをCSVファイルに吐き出すと「h:mm:ss」形式のままでした。

その他

・excelの書式設定を「ユーザー定義(h:mm:ss)」→「時刻」に変更することで解決する場合、
その変更をpython側から実行する方法も知れたら大変助かります。(そのままrange()でうまいこと取得できる方が助かります。)

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

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

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

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

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

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

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

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

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

どうも0.4729というのは11:21:00を24時間で割った値のようです。
以下のようにdatetimeで日割り計算を戻してあげると、時刻になりました。

import xlwings as xw
import datetime 
wb = xw.Book("Book1.xlsx")
sht = wb.sheets['Sheet1']
t = sht.range((1,1),(50,1)).value
print(t)
# [0.47291666666666665, 0.47361111111111115, 0.474305555555556, 0.475,...
def day_to_time(D):
    T = str(datetime.timedelta(days=D))
    return T
d = [*map(day_to_time,t)]
print(d)
# ['11:21:00', '11:22:00', '11:23:00', '11:24:00', '11:25:00', '11:26:00',...

でも、どうせpandas使うなら下のほうが楽ですね。

import pandas as pd
df = pd.read_excel("Book1.xlsx",header=None)
print(df)
"""
    0
0   11:21:00
1   11:22:00
2   11:23:00
3   11:24:00
(中略)
49  12:10:00
"""

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2020/07/03 18:25

    ありがとうございます!
    1こめの方法で解決しました。
    2こめについては学習してみます。
    必要に迫られてpython自体を学習したてということもあり、pandasでもexcel操作ができることを初めて知りました。pandasのread_excelを試してみたところ、excelファイルを保存していなければ反映されないようで、ちょっとこのままでは難しいかなという状態です。
    ただ、dataframeにそのまま読み込んだ方が効率的というのはご指摘いただいたとおりだと思います。非保存の状態から読み込める方法を探しつつ、検討してみます。

    ありがとうございました。

    キャンセル

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

  • ただいまの回答率 88.92%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

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

  • トップ
  • Pythonに関する質問
  • (python,xlwings) xlwingsでexcelから「ユーザー定義」の値(時刻)を、そのままの形式で取得したいです