MENU
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
カテゴリー
  • IT関連 (623)
    • Bootstrap (2)
    • クラウド (4)
    • サーバー技術 (185)
    • ストレージ (7)
      • NetApp (7)
    • ネットワーク技術 (91)
      • Cisco (36)
      • Juniper (18)
      • 負荷分散装置 (17)
    • パソコン関連 (92)
      • MAC (25)
      • Windows (54)
    • プログラミング (154)
      • Ansible (11)
      • C言語 (23)
      • Python (111)
        • Django (20)
    • 仮想化 (88)
      • Docker (63)
      • VMware (23)
  • VPS (200)
    • ABLENET VPS (16)
    • Amazon Lightsail(VPS) (2)
    • ConoHaVPS (37)
    • mixhostVPS (4)
    • WebARENAIndigo (16)
    • XServerVPS (34)
    • お名前.com VPS (12)
    • さくらのVPS (24)
    • カゴヤクラウドVPS (13)
    • シンVPS (7)
  • レンタルサーバー (56)
    • エックスサーバー (38)
  • 光回線 (8)
  • 技術スキルアップ開発・学習 (7)
    • Envader (2)
    • RareTECH (2)
    • Udemy (3)
もう現役20年超えましたー。経験値ならだれにも負けないエンジニア技術ブログ
インフラエンジニアの技術LOG
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
インフラエンジニアの技術LOG
  • VPS(レンタルサーバ)比較
  • ITエンジニアの転職
  • IT技術入門(Engineers.LOG)
  1. ホーム
  2. IT関連
  3. プログラミング
  4. Python
  5. 【Python】openpyxlの「offset」でエクセルのセルの周辺データを取得するプログラム

【Python】openpyxlの「offset」でエクセルのセルの周辺データを取得するプログラム

2020 3/01
Python
2020年3月1日

Pythonでエクセルの特定の文字列のセルの周辺データを取得するためのプログラムを作成しました。

例えば、以下のように、「東京」というセルデータの右側のセルのデータを一括で取得したいときなどに便利です。

  • [東京都] [品川区]
  • [東京都] [墨田区]
  • [東京都] [新宿区]

今回は「openpyxl」ライブラリで「offset」を利用し、対象文字列周辺のセルデータ取得プログラムを書きました。
エクセルデータの取得で参考にしてください。

目次
安くて高速!高性能VPSで快適開発!
最速5分でサーバー構築
>>>こちらをチェック

エンジニア必見! 技術力を伸ばすVPS徹底比較
>>>VPS比較

「openpyxl」の「offset」を利用した指定文字列周辺データを取得するプログラム

今回は以下のエクセルのセルデータの文字列で「tmpfs」に該当する右隣のセルのデータを取得します。

※ excel-data.xlsx

「offset」コマンドを使用したセルの周辺データ取得プログラム

以下のプログラムは特定のセルデータの中から、「tmpfs」という文字列を検索し、その隣のセルデータを取得します。

※ offset-test01.py

import openpyxl as px

wb = px.load_workbook('excel-data.xlsx')

ws = wb["Sheet1"] 

B2_COL = 2
B8_ROW = 2

E2_COL = 6
E6_ROW = 6

# 範囲データを順次処理
for row in ws.iter_rows(min_col=B2_COL, min_row=B8_ROW, max_col=E2_COL, max_row=E6_ROW ):
    for cell in row:
        # 該当セルの値取得
        cell_value = cell.value
        o = cell.offset(0,1)
        offset = o.value
        # セル範囲内に該当の文字列が存在する場合表示
        if 'tmpfs' in cell_value:
            print(cell.coordinate, cell_value, offset)

# ロードしたExcelファイルを閉じる
wb.close()
  • 1行目:「openpyxl」をインポート
  • 3行目:対象のエクセルファイルを読み込み
  • 5行目:読み取ったエクセルから対象のシートをアクティブ
  • 7−11行目:データを取得する範囲のセルの情報を取得
  • 14行目:ws.iter_rowsで対象シートのセルの範囲を指定
  • 17行目:セルのデータを取得
  • 18−19行目:対象の文字列の右隣のデータを取得
  • 21−22行目:対象の文字列があった場合、右隣のデータを表示する

実行結果

以下でプログラムを実行することにより、対象の文字列とその右隣のセルのデータが出力されます。

offset-test $ python3 offset-test01.py 
B2 devtmpfs 908M
B3 tmpfs 920M
B4 tmpfs 920M
B5 tmpfs 920M

「offset」で周辺データは自由に取得可能

上記プログラムで、offsetの数値を変更することで自由にセルの周辺データを取得できます。

対象のセルの右隣のデータを取得

o = cell.offset(0,1)

対象セルの左隣のデータを取得

o = cell.offset(0,-1)

対象セルの一つ下のデータを取得

o = cell.offset(1,0)

対象セルの一つ上のデータを取得

o = cell.offset(-1,0)

openpyxlの「offset」を利用したプログラムは以上となります。

エンジニアスキルをアップする勉強法

ITエンジニアの開発・検証・学習としてインターネット上で専用のサーバ(VPS)を利用しましょう!
実務経験はVPSで学べます。

あわせて読みたい
現役エンジニアがおすすめするVPSレンタルサーバ比較(高速SSD限定) 格安VPS比較(2025年最新版)

Python
よかったらシェアしてね!
  • URLをコピーしました!
  • URLをコピーしました!

コメント

コメントする コメントをキャンセル

email confirm*

post date*

日本語が含まれない投稿は無視されますのでご注意ください。(スパム対策)



検索
カテゴリー
新着記事
  • XServerVPS アニメ風 男の子 プログラミングをしている VPSを利用している 楽しそうにしている
    XServerVPSで証明書(SSL)を取得する方法
    2025年3月24日
    XServerVPS
  • レンタルサーバ アニメ風 女の子 楽しんでパソコンをしている 目がキラキラ
    WordPressがレンタルサーバよりVPSで利用する方がおすすめの理由
    2025年3月19日
    VPS
  • VPS レンタルサーバー アニメ風 女の子 プログラミングをしている VPSを利用している 楽しそうにしている
    VPSとクラウドの違いとは?初心者向けにわかりやすく解説
    2025年3月5日
    VPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSはWindows serverを利用できない。その理由と利用できるOSは?
    2025年3月4日
    シンVPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSでゲームを利用する環境はあるのか
    2025年3月4日
    シンVPS
  • シンVPS アニメ風 女の子 パソコン プログラミングをしている VPSを利用している 楽しそうにしている
    シンVPSのサイトの表示速度は他社に比べて早いのか?
    2025年3月4日
    シンVPS
目次
目次