🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Python

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

Q&A

解決済

1回答

7827閲覧

pythonでエクセルファイルにパスワードを設定したい

nishimon

総合スコア7

Python

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

0グッド

0クリップ

投稿2021/02/25 02:31

イメージ説明
エクセルを開いた際に、pythonコード内でパスワードを設定してエクセルを保存したい。

pywinを用いてパスワードを解除することはできたのですが
pywinを用いてパスワードを再設定して保存することができません。
openpyxlでブックの保護ができるのは確認済みですが、パスワードを設定するのはサポートされていないようです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

pywin32をご利用なので、Windows環境を前提に回答します。

python3.7

1import win32com.client as win32 2filename = 'sample.xlsx' # 適宜変更してください。 3password = 'test' # 適宜変更してください。 4excel = win32.Dispatch('Excel.Application') # 以降はExcelVBAを書くつもりで。 5bk = excel.Workbooks.Open(__file__[:-8]+filename, False, False, None, password) # -8の部分は適宜変更してください。 6sheet=bk.Worksheets("Sheet1") 7sheet.Activate() 8sheet.Range("A1").Value="1" 9bk.SaveAs(__file__[:-8]+"_"+filename, 51, password) # -8の部分は適宜変更してください。念のためファイル名先頭に"_"をつけて保存するようにしています。 10bk.Close()

Win 10 Pro(64bit)
Excel2016 (64bit)
Python3.7 (64bit)※Anaconda2020.02
にて動作確認済み。

投稿2021/02/25 08:30

編集2021/02/25 09:06
yag1kaz

総合スコア253

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

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

nishimon

2021/03/01 07:27

回答ありがとうございます。 試します!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問