[デバッグ] > [ウィンドウ] > [例外設定] を開いて
例外が発生した時点で停止したい例外にチェックを入れます。
よくわからないなら、全部チェックして止めて
余計なのは少しずつOFFすればよし
[デバッグ] > [ウィンドウ] > [例外設定] を開いて
例外が発生した時点で停止したい例外にチェックを入れます。
よくわからないなら、全部チェックして止めて
余計なのは少しずつOFFすればよし
以下をフォームのコードに追加
' CreateParams プロパティをオーバーライドする Protected Overrides ReadOnly Property CreateParams() As System.Windows.Forms.CreateParams Get Const CS_NOCLOSE As Integer = &H200 Dim DcreateParams As System.Windows.Forms.CreateParams = MyBase.CreateParams DcreateParams .ClassStyle = DcreateParams .ClassStyle Or CS_NOCLOSE Return DcreateParams End Get End Property
Form1_Load()で復元処理して、FormClosing()で保存処理する
以下はレジストリ使った例
Private Sub FormHoge_Load(sender As Object, e As EventArgs) Handles MyBase.Load Dim regkey As Microsoft.Win32.RegistryKey = Microsoft.Win32.Registry.CurrentUser.CreateSubKey("Software\hoge\param") Dim size As Size size = New Size(regkey.GetValue("w", 1024), regkey.GetValue("h", 768)) Me.ClientSize = size Dim point As Point point = New Point(regkey.GetValue("x", 0), regkey.GetValue("y", 0)) Me.Location = point End Sub
Private Sub FormHoge_FormClosing(sender As Object, e As FormClosingEventArgs) Handles MyBase.FormClosing Dim regkey As Microsoft.Win32.RegistryKey = Microsoft.Win32.Registry.CurrentUser.CreateSubKey("Software\hoge\param") regkey.SetValue("w", Me.ClientSize.Width) regkey.SetValue("h", Me.ClientSize.Height) regkey.SetValue("x", Me.Location.X) regkey.SetValue("y", Me.Location.Y) End Sub
ApplicationSettingsを使ったやつだと
DLLで実装した場合、再起動するとすべて忘れてしまった。
あとClientSizeは思ったとおりにならない罠があるらしい。
アドイン「Table of Contents Plus」を導入して、
「基本設定」→「以下のコンテンツタイプを自動挿入」のpostとpageのチェックを外し、
目次を表示したいページのどこかに
[toc]
とショートコードを追加する。
Function RemoveExtension(aFilename As String) As String '--- 拡張子の位置 ---' Dim posExt As Long posExt = InStrRev(aFilename, ".") '--- 拡張子を除いたパス(ファイル名)を格納する変数 ---' Dim strFileExExt As String If (0 < posExt) Then RemoveExtension = Left(aFilename, posExt - 1) Else RemoveExtension = aFilename End If End Function
・必要なものがExcelForSQLite3としてまとまってるのでありがたくダウンロード。
github.com
・zipDLして解凍した中にあるDLLをSqliteを利用するxlsmファイルと同じ場所におく。
32bitExcelならsqlite3.dll/SQLite3_StdCall.dllを
64bitExcelならx64フォルダにあるsqlite3.dllを使いましょう。
・SQLite3VBAModulesフォルダの中に標準モジュールがあるのでVBAのファイルのインポートで取り込む。
32bitExcelならSqlite3.bas / Sqlite3Demo.bas
64bitExcelならSqlite3_64.bas / Sqlite3Demo_64.bas
・Sqlite3Demoの中のAllTests()を呼び出して問題なく動いたらOK
Dim list As New ArrayList list.Add("A") list.Add("B") String.join(",",list.ToArray());