list() について
リストをa=[1,2,3,4,5]のように指定できることはご存知でしょう。
今回は、リストの中にリストを作ってみる。
a=['あ','い','う','え','お']
ka=['か','き','く','け','こ']
sa=list("さしすせそ")
ta=list('たちつてと')
na=list('なにぬねの')
ha=list('はひふへほ')
ma=list('まみむめも')
ya=list('や ゆ よ')
ra=list('らりるれろ')
wa=list('わ を ん')
とりあえず、ひらがな五十音をそれぞれあ行から、ワ行までリストを作った。
ちなみに、list('かきくけこ')と['か','き','く','け','こ']
は同じ意味を持つ。
ここで、これらをまとめたリストを作成する
hiragana1=[a,ka,sa,ta,na,ha,ma,ya,ra,wa]
hiragana2=list(a+ka+sa+ta+na+ha+ma+ya+ra+wa)
この二つのリストの違いはわかるだろうか
hiragana1は、リストをリストにしている。
hiragana2は、リストをまとめている。
print(hiragana1)
[['あ', 'い', 'う', 'え', 'お'], ['か', 'き', 'く', 'け', 'こ'], ['さ', 'し', 'す', 'せ', 'そ'], ['た', 'ち', 'つ', 'て', 'と'], ['な', 'に', 'ぬ', 'ね', 'の'], ['は', 'ひ', 'ふ', 'へ', 'ほ'], ['ま', 'み', 'む', 'め', 'も'], ['や', ' ', 'ゆ', ' ', 'よ'], ['ら', 'り', 'る', 'れ', 'ろ'], ['わ', ' ', 'を', ' ', 'ん']]
print(hiragana2)
['あ', 'い', 'う', 'え', 'お', 'か', 'き', 'く', 'け', 'こ', 'さ', 'し', 'す', 'せ', 'そ', 'た', 'ち', 'つ', 'て', 'と', 'な', 'に', 'ぬ', 'ね', 'の', 'は', 'ひ', 'ふ', 'へ', 'ほ', 'ま', 'み', 'む', 'め', 'も', 'や', ' ', 'ゆ', ' ', 'よ', 'ら', 'り', 'る', 'れ', 'ろ', 'わ', ' ', 'を', ' ', 'ん']
どちらが使いやすいかは、状況によって異なると思うけど、hiragana1はまとまりがあってわかりやすい。
ここで、さ行のsu
「す」を取り出したい時には、
print(hiragana1[2][2])
このように記述する。
リストの中身を書き換えたい時は、直接していてあげれば良い
a[0]= "阿"
print(a)
['阿', 'い', 'う', 'え', 'お']
リストに要素を追加する
リストに要素を追加したい時は、append() を用いる。
ka.append('が')
print(ka)
['か', 'き', 'く', 'け', 'こ', 'が']
ちなみに、リストをappend() すると、リストにリストが追加される。
sa.append(ta)
['さ', 'し', 'す', 'せ', 'そ', ['た', 'ち', 'つ', 'て', 'と']]
inset() を使うと、最後尾ではなく指定のポジションに要素を追加することができる。
a.insert(2,"ゐ")
print(a)
['阿', 'い', 'ゐ', 'う', 'え', 'お']
del を使えば、**リストから要素を削除**することができる。
del a[1]
print(a)
['阿', 'ゐ', 'う', 'え', 'お']
例えば
「く」が「か行」にあるが、何番目にあるかわからない場合、remove() を使って消すことができる。
ka.remove("く")
print(ka)
['か', 'き', 'け', 'こ', 'が']
要素の在処をさぐる
「く」のように、どこにあるのかわからない場合、index() を使うことで何番目にあるのか知ることができる。
#サ行の「せ」を探す。
print(sa.index('せ'))
3
しつこいようだが、3=4番目ということだ
しかし、「せ」を探して「た行」を当たってしまった場合、怒られてしまう。
いちいちエラーになっててはしょうがないので、こういう時、in を使って、True Falseのブール値を割り出す。
"せ" in ta
False
Falseが帰ってきたので、「せ」はた行になかった。
では、hiraganaリストの中に「せ」が存在するのか、調べたい時にhiragana1かhiragana2どちらを使えば良いだろう?
答えは、hiragana2。こちらはすべての文字が一つずつリストになっているので、Trueが帰ってくる。
"せ" in hiragana2
True
しかし、hiragana1で探すと、Falseが帰ってくる。
"せ" in hiragana1
False
これは、hiragana1に「せ」というリストが存在しないから。「さしすせそ」というリストが認識されているためだ。
場合によってhiragana1とhiragana2を使い分けるとは、このことである。
というわけで、よくわからないものをリスト化して持ってきた場合、まず「in」を使って存在の有無を調べ、
次にindex() でそれがどこに存在するのか知るというのが真っ当な手順になる。
個数の割り出し
リストに同じ文字がいくつ含まれているのかを知るには、count() を使う。
print(hiragana2.count(" "))
4
上記は、hiragana2に空白がいくつ含まれているか調べた。や行とわ行に2つずつあるので4とかえってきた。
文字列への変換
リストを文字列に変換するには、join() を用いる。
print(','.join(hiragana2))
あ,い,う,え,お,か,き,く,け,こ,さ,し,す,せ,そ,た,ち,つ,て,と,な,に,ぬ,ね,の,は,ひ,ふ,へ,ほ,ま,み,む,め,も,や, ,ゆ, ,よ,ら,り,る,れ,ろ,わ, ,を, ,ん
#こいつを綺麗にあ〜んまで並べたい時はさらに
print(','.join(hiragana2).replace(',','').replace(' ',''))
あいうえおかきくけこさしすせそたちつてとなにぬねのはひふへほまみむめもやゆよらりるれろわをん
ソート
なんとソート機能まである。
sorted(リスト)とするだけ。これで昇順になる。はたして、ひらがなはうまくいくだろうか。
一度最初の綺麗なあいうえお順にもどして、ばらばらに行を並べたhiragana3を作って試してみよう
hiragana3=sa+a+na+ka+wa+ta+ra+ma+ya+ha
print(sorted(hiragana3))
[' ', ' ', ' ', ' ', 'あ', 'い', 'う', 'え', 'お', 'か', 'き', 'く', 'け', 'こ', 'さ', 'し', 'す', 'せ', 'そ', 'た', 'ち', 'つ', 'て', 'と', 'な', 'に', 'ぬ', 'ね', 'の', 'は', 'ひ', 'ふ', 'へ', 'ほ', 'ま', 'み', 'む', 'め', 'も', 'や', 'ゆ', 'よ', 'ら', 'り', 'る', 'れ', 'ろ', 'わ', 'を', 'ん']
綺麗にならんだ!
ここでわかったのは、空白文字の方が優先順位が高いことだ。(どうでもいい)
もうひとつ、sort() を使うことができる。これは、リストそのものを書き換える。
hiragana3.sort()
print(hiragana3)
[' ', ' ', ' ', ' ', 'あ', 'い', 'う', 'え', 'お', 'か', 'き', 'く', 'け', 'こ', 'さ', 'し', 'す', 'せ', 'そ', 'た', 'ち', 'つ', 'て', 'と', 'な', 'に', 'ぬ', 'ね', 'の', 'は', 'ひ', 'ふ', 'へ', 'ほ', 'ま', 'み', 'む', 'め', 'も', 'や', 'ゆ', 'よ', 'ら', 'り', 'る', 'れ', 'ろ', 'わ', 'を', 'ん']
辞書
辞書(dictionary)はリストに似ているが
{key:値}のペアでリスト化されている。
それぞれのキーを参照すると、値が出てくるといった感じだ。
student={'小学生':'6-12歳','中学生':'13-15歳','高校生':'16-18歳','大学生':'18-22歳'}
これは、小学生から大学生までの年齢を辞書に収めていることを示す。
まぁ僕みたいに2年も3年も回り道している人はズレてしまうけど。
#中学生の年齢を知りたい時print(student['中学生'])
print(student['中学生'])
では、この辞書に大学生が存在しているのか知りたい時は、
'大学生' in student
とすればよいが、ここで問題。
練習問題
解答
if '大学生' in student:
print(student['大学生'])
else:
print('見つかりませんでした')
大切なのは、見つからなかった場合のelseもちゃんと書くこと。
ここで、大学生の年齢を18-24に広げたいとする。
```py student['大学生']="18-24" print(student['大学生'])
18-24
<p>これでちゃんと書き換えられている。<p>
<h2>辞書同士の結合</h2>
<p>大学院生 23-24、博士 25-28を加えたいとする。<p>
<p>over_student={'大学院生':'23-24','博士':'25-28'}<p>
<p>とすることで、追加の辞書を作成する。ここに、**update()** 関数を使ってstudentに加えてあげよう<p>
```py
student.update(over_student)
print(student)
{'高校生': '16-18歳', '中学生': '13-15歳', '大学生': '18-22歳', '小学生': '6-12歳', '博士': '25-28', '大学院生': '23-24'}
これで無事、大学院生と博士がstudentの仲間入りを果たすことができた。
ここから、*やっぱり博士はいらないや★*と考える人がいたら、delを使って、同じように削除することができる。
del student['博士']
print(student)
{'高校生': '16-18歳', '中学生': '13-15歳', '大学生': '18-22歳', '小学生': '6-12歳', '大学院生': '23-24'}
全てを消し去りたい時は、clear() 関数をつかう。
student.clear()
print(student)
{}
キーの取得
辞書にどんなキーが含まれているのかわからなければ、その辞書は使い物にならない。
そんな時に使うのが、keys() 関数だ。keyではない、keysだ
#over_studentを加えたstudent辞書を使う
print(student.keys())
dict_keys(['高校生', '中学生', '大学生', '小学生', '博士', '大学院生'])
これで、どんなキーが含まれているのか知ることができた(なんで大学院生が後に来てるんだろう)
このkeys() によって出したキーはlist() で囲むことによってリスト化することができる。
全ての値の取得
キーとは反対に値を知りたい時、values
を使うことで調べることができる。
student.values()
dict_values(['16-18歳', '13-15歳', '18-22歳', '6-12歳', '25-28', '23-24'])
さらに、キーと値のセットを調べたい時は、items() を使う。
student.items()
dict_items([('高校生', '16-18歳'), ('中学生', '13-15歳'), ('大学生', '18-22歳'), ('小学生', '6-12歳'), ('博士', '25-28'), ('大学院生', '23-24')])
本日はこれにて終了。