そもそもの話ですが
!はセルの中でlinuxコマンドを実行する為のものです。
内情は詳しくありませんが、セルが実行された際に先頭に!がある場合、colaboratoryはそのセルにはlinuxコマンドであると認識してインスタンス上でコマンドを実行します。
先頭にそれがない場合はpythonプログラムとして認識され実行されます。
今回のコードは1行目の先頭に!がないので、セル全体がpythonコードとして認識され、その中で!を使用しているので、うまくいかないのだと思います。
(pythonの文法として!wgetが存在しない為)
なので、pythonコードとlinuxコードを混在させることはこの方法ではできないかと思います。
やりたいことを実現する方法は多分、2つあって
①pythonからlinuxコマンドを呼び出す
②pythonでファイルを保存する
です。
①はsubprocessというモジュールを使用します。
python
1import subprocess
2
3# 成功か失敗かを返却する
4res = subprocess.call('ls')
なので、res = subprocess.call('wget -q #{url}')
と書けばできそうな気がします。
(保存先などの指定が必要かもしれません。)
ただ、自分も昔使用したことがありますが、(個人的に)直感的ではない部分があります。
引数を追加するときは分割しなきゃいけないとかちょっと使い方は忘れてしまいました。
②はrequestsの様なモジュールを使用する方法です。
モジュール自体はrequestsとかrequestとかいろいろあって好きなのを使えばいいと思いますが、以下のサイトを参考にするといいと思います。
https://pycarnival.com/urlretreive_urlopen/
とか
https://qiita.com/toshikawa/items/2d535906b42b9332b743
最初のページはコード的にわかりやすいかと、最後のリンクはpythonでwgetができると書いているのでやりたいことを実現する方法であると思います。
上記の方法を知っている場合は、pythonのコマンドとlinuxコマンドを!を使用して混在させることはできないので、pythonでファイルをダウンロードするプログラムを書くか、linuxコマンドやシェルでファイルをダウンロードする物を書くかどちらかしか方法はないという回答になるともいます。