アプリ版:「スタンプのみでお礼する」機能のリリースについて

= (イコール)で始まるセルの値を取得する方法について教えてください。

エクセルVBAでCSVファイルを取り込み(現状手でコピー)→mysqlに挿入というプログラムを実装しています。

その中で、CSVファイル(もしくはタブ区切りテキストファイル)の中に、+ (プラス記号)で始まるデータがありました。

エクセルで開いた場合、+が =+に変換されてしまい、#NAME? となってしまいました。
このセルに対してValueを取得すると、型が一致しません。のエラーが出ます。

取り込んだ時点でValueが取得できないため、値を変換しようにもできません。

もし、良い方法が思いつく方がいらっしゃれば教えていただけませんでしょうか。

以上、よろしくお願いいたします。

A 回答 (2件)

他に『=』文字が使われてなければ「置換」で消してしまっても良いかと思います。


あるいは『=+』を『+』、『=-』を『-』に置換するとか。
でも、
>エクセルVBAでCSVファイルを取り込み(現状手でコピー)
これは、CSVファイルをそのまま新規Bookとして開いて、データ範囲をコピーしているという意味でしょうか。
別の手法として、[外部データの取り込み]機能を使えば、既存シートにデータ取り込みができます。
まずは手作業でやって、マクロ記録してみてください。
QueryTablesオブジェクトを用いた参考コードが得られます。

2003の場合、[データ]-[外部データの取り込み]-[データの取り込み](ファイルの種類を「すべてのファイル」にする)...
2007の場合、[データ]-[外部データの取り込み]-[テキストファイル]...
ここから[テキストファイルウィザード]が開きます。
区切り文字を指定して、[テキストファイルウィザード - 3/3 ]のウィンドウで列のデータ形式を選択できます。
この時、全て『文字列』で読み込めば数式変換はされません。
    • good
    • 0

もともと=で始まるのかどうかわかりませんよね。


+で始まるなら'で囲んでもらうとかしないと。
    • good
    • 1

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!