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

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

新規登録して質問してみよう
ただいま回答率
85.35%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

2回答

1397閲覧

文字列の中間部分を抜き出したい

heine

総合スコア10

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2020/05/17 12:09

前提・実現したいこと

VBAにて文字列の中間部分だけを抜き取りたいです。


注文書A00001(堀 由文201901).xlsx
注文書A00002(田中 正太郎201901).xlsx

上記の名前の部分のみを抜き取りたいのです。
文字数が違っていても同じコードで抜き取れるようにしたいです。

試したこと

Cells(1, 1) = Mid(tnt, 11, InStr(tnt, 2019))

### その他
質問の内容が不足してましたら、ご指摘ください。
よろしくお願いします。

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

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

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

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

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

guest

回答2

0

空白で分割し、201901を空文字に置換

VBA

1Cells(1, 1) = Replace(Split(tnt)(1), "201901", "")

日付部分を除去

VBA

1Cells(1, 1) = Replace(tnt, "201901", "")

投稿2020/05/17 16:08

編集2020/05/18 01:25
sazi

総合スコア25327

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

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

heine

2020/05/18 01:20

回答ありがとうございます。 こちらのコードですと名前のみの出力ができなかったので、他者様をベストアンサーにさせていただきました。
sazi

2020/05/18 01:24

名前って姓名ですか? どちらか分からなかったのでsplitで分割していますので、そうじゃないならsplitを外せば良いだけですので、追記しておきます。
heine

2020/05/18 01:39

追加の回答ありがとうございます。 私の説明不足と知識不足で、誤解を生んでいたようで申し訳ありません。 いただいたコードで問題なく動きました。 ありがとうございました。
guest

0

ベストアンサー

変わるのは、氏名と思われる、"("の後から、"2019"の前までと仮定して
Mid(tnt, 11, InStr(tnt, "2019") - 11)

ポイントは、以下
InStrの2つ目の引数は文字列なので、数字を指定してはいけない。
Midの3つ目の引数は、文字数なので、"注文書~("分の11文字を引く必要がある。

VBAに限らず、思い通りに動かない場合は、検索などで関数の仕様を確認するほうが良いかと思います。

投稿2020/05/17 13:01

YT0014

総合スコア1750

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

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

heine

2020/05/18 01:21

回答ありがとうございます。 ベストアンサーにさせていただきました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問