Cursorを使ってコーディングしてみた
コーダーやエンジニアの皆さんはどのくらい使っているでしょうか。
無料で使えるのと言えば、Visual Studio Codeが代表的だと思います。
基本的にはこれだけで十分だと思いますが、CursorというAIが使えるエディタが話題になってきてましたので触ってみる機会を作りました。
それではみていきましょう。
Cursorについて
Cursorは下記からダウンロードできます。
何ができるのかというと、ChatGPTのようなツールをコード上で呼び出して使えるといったイメージでしょうか。
gpt-4oやclaude-3.5-sonnetなどの有名どころも使えます。
新しいバージョンのAIが登場すると割と早めに導入されるイメージですね。
![](https://freefuntimes.com/wp-content/uploads/2024/10/6e3bcb22f8d9ce7541294a39b2d55ad0.jpg)
Visual Studio Codeの拡張機能は引き継がれるため、気軽に使うことができます。これは便利ですねー
執筆時点での料金プランは下記になっています。
![](https://freefuntimes.com/wp-content/uploads/2024/10/2342eabbfa9fae804bc2b80d7c2e0e0a-1030x203.png)
お試しで使うなら無料プランでも十分だと思いますが、実務で使うならプロプランがおすすめでしょうか。
使いたい目的に応じて検討するのがいいと思います。
Cursorを使ってみる
例として公式のキャプチャを用意して、添付して命令してみました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/06912a7f1b04d1f59bb438058ba17bdc.jpg)
回答が返ってきました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/cfdad13ccb624e49a4c40c41551b5f85.jpg)
![](https://freefuntimes.com/wp-content/uploads/2024/10/4a6d3f1a912f247846900c133d96bf51.jpg)
右上の方にAsk、Copy、Applyとありますがなんでしょうか。
- Ask:これは回答結果に満足いかない場合に再命令したい時に使います
- Copy:コードをコピーしたい時に使います
- Apply:変更を適用したい時に使います
ざっくりと上記のようなイメージになっています。Applyをすると下記のようになりました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/d9c32937f6b19f0c6eaa0c48cd10eb4b-1030x536.gif)
想像してたイメージとは違いましたが、なんかいい感じに仕上げてくれていますね。
で、これ自体は他のAIツールでも同様のことができますよね。ここからCursorの便利なところになります。
Cursorのエディット機能
⌘+Kまたは任意のテキストを範囲選択しEditをクリックすれば、エディット機能が使えます。
できることはチャット機能と同じですが、同じファイル内で立ち上げられるのが効率よく作業ができます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/e085b3b45ef61d6cebc511d0c868e5c2.jpg)
実際に命令してみます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/3d64115def682837344f4b51cab32cec.jpg)
回答が返ってきました!
![](https://freefuntimes.com/wp-content/uploads/2024/10/1f25a378748886098000c729f420351d.jpg)
修正前が赤色マーカー。修正後が緑色マーカーです。⌘+Yで適用する、⌘+Nで適用しないを選べます。
そこまで難しくはないですね。
一方で⌘+Lで、右側の方に画面が現れますが、「@ 」を使うとファイルやコードを辿ったりできます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/277b56fd939c2e47b74b6713d7926b5f.jpg)
@ Codebaseを使用すれば、開発しているコード全体に対して聞けるので便利ですよ。
Cursorのサジェスト機能(Copilot++)
設定から添付部分をenabledにしておきましょう。
![](https://freefuntimes.com/wp-content/uploads/2024/10/5a7b54ab9ec109b6a80959ad3cff11a4.jpg)
下記も対応しておきます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/c727c0027ba5c1a99c7bce5b228dd489.jpg)
これでコードを書いているときに、AIが予想して候補を出してくれるようになります。無料プランだと制限があるので、ある程度使ってしまうと予測が出なくなります。自分の場合はそうでした。
JavaScriptやWordPressのphpなどを書いているときは結構重宝しました。
使用感としてはGitHub Copilotに少し近いのではないかと思います。いろんなツールに課金している方にとっては、Cursorに集約するのもありな気がしました。
ほんとに最近はなんでもサブスクの時代なので結構困りますね。節約できるところは節約していきましょう。
サジェスト機能で個人的に便利なのをまとめるとこんな感じでしょうか。
- クラス名の予測をしてくれる
- 繰り返し系(リストなど)の予測をしてくれる
- JSやPHPの記述を予測してくれる
- テキストを予測してくれる
- 綴りの間違いを指摘してくれる
- コードのミスを指摘してくれる
個人的に便利な実例集
都道府県を出力
都道府県を手打ちしたり、コピペして持ってくるのって案外面倒ですよね。腱鞘炎にならないうちにやってもらいます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/bbd9f19b9652480672bad838fcc39d00.jpg)
下記のように一瞬で出力してくれます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/b2537302c3338b9c2636322f556ddcc1.jpg)
連番
これも案外面倒です。Visual Studio Codeのショートコードでできないこともないですが、頭の中で考えるの面倒じゃないですか。なのでこれもやってもらいます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/8df3f0c315d72770ac7207949f1eaa9b.jpg)
こんな感じで簡単に作ってもらえます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/1fefc6e7f8ae6ebbbd018cc959ee9aef.jpg)
クラス名考えてもらう(日本語から英語を推測)
これも面倒な時ありますよね。下記は少なめの例ですが、コードが多いほど便利だと思います。sectionごとにやってもらうとかがよさそうです。
![](https://freefuntimes.com/wp-content/uploads/2024/10/c34a92923b809232594d079d570a15f0.jpg)
回答返ってきましたが、うまくいかなかったため、再度命令。
![](https://freefuntimes.com/wp-content/uploads/2024/10/8681a526eaf210e3394438d1402f6bda.jpg)
細かいことは置いておいて、まあいい感じじゃないでしょうか。
![](https://freefuntimes.com/wp-content/uploads/2024/10/6d20379871bc91c829a66e3d917e4704.jpg)
カレンダー出力
これもテーブルなどで記載していくの面倒ですよね。年単位だとさらに面倒です。下記は月の例です。
![](https://freefuntimes.com/wp-content/uploads/2024/10/a9e2f02bc7ba9e2081a65a707476cde0.jpg)
出力されたが、年があっていなかったです。ただ曜日の始まりもコントロールできるのはいいですね。
![](https://freefuntimes.com/wp-content/uploads/2024/10/a00f3cd869f86282665ce18c005d77e6.jpg)
修正します。
![](https://freefuntimes.com/wp-content/uploads/2024/10/fe02dcce3aaf06f42bd1485e0f3ab1f1.jpg)
無事修正できました!
![](https://freefuntimes.com/wp-content/uploads/2024/10/3f6f1e9d8e471d7e4bcff6cdd0c39176.jpg)
ソースは下記のようになりました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/ba6aceb7d1d0d47bff7948bc77985c2d.jpg)
十分すぎる出来ではないかと思います。
画像や手書き文字を読み取ってもらう
これはお試しでやってみました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/09919c99456075f51e67236e8fa80b23.jpg)
結果です。
![](https://freefuntimes.com/wp-content/uploads/2024/10/8f54ad12bd32bb055a7e2ab76723f82b.jpg)
両方は無理なようです。では続いて下記ではどうでしょうか。
![](https://freefuntimes.com/wp-content/uploads/2024/10/6dbdfce819cce87a349a6d43eb271737.jpg)
手書きはやはり使えないですね。また文字上に線を引いて修正させるのもまだ難しいようです。
![](https://freefuntimes.com/wp-content/uploads/2024/10/0d179c45e235f5f941a538e9c1ad4540.jpg)
テキスト拾うの面倒なときはやってもらう
これは価格表やリストなどで使えると思います。果物のリストの例です。
![](https://freefuntimes.com/wp-content/uploads/2024/10/eb4db0708ade98265f6647e369b12071.jpg)
見事にうまくいきました!
![](https://freefuntimes.com/wp-content/uploads/2024/10/b24c0443d2860430dd08587423217020.jpg)
JSが伴う機能面を作ってもらう
今回はタブ切り替えの例でやってみましょう。
![](https://freefuntimes.com/wp-content/uploads/2024/10/50ad5d4957e4c93e1988269423ca988a.jpg)
実際に生成されたのがこちら。
![](https://freefuntimes.com/wp-content/uploads/2024/10/71e2afa61772f66d89d99371bbaa78dc.gif)
なかなかいい感じですね。これをカスタマイズしていけば普通に作れそうです。一応生成されたコードも貼っておきます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/0893594a92ac337d9f0d37d25bf76a20.jpg)
![](https://freefuntimes.com/wp-content/uploads/2024/10/32871887f13076746b70617baeead861.jpg)
![](https://freefuntimes.com/wp-content/uploads/2024/10/a6bfbb27bf0e62a84520e4b718c7ebbe.jpg)
タブ切り替え以外でも、結構実務で使えるレベルで生成してくれます。とはいえそのまままるまる同じコードは使わないよう注意しましょう。
環境構築(先ほどのファイルをAstroに書き換える)
環境構築もできないかなと思って試してみました。Codebaseを使って全体のファイルを見るようにして命令しました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/96ec6e63c15b772594c92b4c6169497f.jpg)
自動で生成してくれませんでしたが、右側にこの手順で実行してとありましたので、その通りにやってみます。
![](https://freefuntimes.com/wp-content/uploads/2024/10/8e561e0a1a6352bb4322a2933651127d.gif)
実際にできあがった画面はこちらです。タブ切り替えもいい感じにデザインしてくれました!
![](https://freefuntimes.com/wp-content/uploads/2024/10/795a2362eb60bfa08a8f7ed3a9a25790.jpg)
Chromeの拡張機能でも確認したところ、Astroが使われていました。
![](https://freefuntimes.com/wp-content/uploads/2024/10/710bad784a6871d759f6dc404df8d362.jpg)
今後さらに発展していくと自動でやってくれるようになるのですかね。
ちなみに、このAstroからReact/Next.js構成に書き換える命令をしてみましたが、これはうまくいきませんでした。
まだ課題はたくさんありそうですが、実務で使えることも多く、いろんな発見がありました。
また何かあれば書いていきたいと思います。