Stringio-binary-options

Stringio-binary-options

Krzysztof-chodorowski-forex-trading
Stock-options-in-spanish
Forex-trading-in-urdu-dailymotion


Lifesdream-forex-trading Pilihan pilihan-biner fx Binary-options-trading-system-2016-ncaa Skrip Forex-easy-order Pilihan-opsi biner Titan Indikator opsi biner-kedua

Panduan untuk Memasarkan Opsi Biner di AS Opsi biner didasarkan pada proposisi ya atau tidak sederhana: Akankah aset dasar berada di atas harga tertentu pada waktu tertentu Trader melakukan perdagangan berdasarkan apakah mereka yakin jawabannya adalah ya atau tidak, membuat Itu salah satu aset keuangan paling sederhana untuk diperdagangkan. Kesederhanaan ini telah menghasilkan daya tarik yang luas di antara para pedagang dan pendatang baru di pasar keuangan. Sesederhana kelihatannya, para pedagang harus benar-benar memahami bagaimana opsi biner bekerja, pasar dan kerangka waktu apa yang dapat mereka tukar dengan opsi biner, keuntungan dan kerugian dari produk ini, dan perusahaan mana yang diberi wewenang secara hukum untuk memberikan opsi biner kepada penduduk A.S. Opsi biner yang diperdagangkan di luar A.S. biasanya terstruktur secara berbeda dari pada biner yang tersedia di bursa A.S. Saat mempertimbangkan berspekulasi atau melakukan lindung nilai. Pilihan biner adalah sebuah alternatif, namun hanya jika trader sepenuhnya memahami dua kemungkinan hasil dari pilihan eksotis ini. (Untuk bacaan terkait, lihat: Apa yang Perlu Anda Ketahui Tentang Opsi Biner di Luar A.S.) Pilihan Biner A.S. Dijelaskan Pilihan biner memberi jalan ke pasar perdagangan dengan risiko terbatas dan potensi keuntungan terbatas, berdasarkan proposisi ya atau tidak. Misalnya: Akankah harga emas berada di atas 1.250 at 1:30 p.m. Hari ini Jika Anda yakin itu akan, Anda membeli opsi biner. Jika berpikir emas akan berada di bawah 1.250 at 1:30 pm Maka Anda menjual opsi biner ini. Harga opsi biner selalu antara 0 dan 100, dan sama seperti pasar keuangan lainnya, ada tawaran dan harga permintaan. Biner di atas mungkin diperdagangkan pada 42,50 (tawaran) dan 44,50 (penawaran) pada pukul 1 siang. Jika Anda membeli opsi biner benar maka Anda akan membayar 44,50, jika Anda memutuskan untuk menjual dengan benar maka Anda akan menjual di 42,50. Mari kita asumsikan Anda memutuskan untuk membeli di 44,50. Jika di 1:30 p.m. Harga emas di atas 1,250, pilihan Anda berakhir dan nilainya 100. Anda menghasilkan keuntungan 100 - 44,50 55,50 (lebih sedikit biaya). Ini disebut berada dalam uang. Tapi kalau harga emas di bawah 1.250 at 1:30 p.m. Opsi berakhir pada 0. Oleh karena itu Anda kehilangan 44,50 yang diinvestasikan. Ini disebut keluar dari uang. Tawaran dan penawaran berfluktuasi sampai opsi berakhir. Anda dapat menutup posisi Anda kapan saja sebelum kadaluwarsa untuk mengunci keuntungan atau mengurangi kerugian (jika membiarkannya habis masa berlakunya habis). Akhirnya setiap pilihan mengendap pada 100 atau 0 100 jika proposisi opsi biner benar, dan 0 jika ternyata salah. Dengan demikian setiap opsi biner memiliki potensi nilai total 100, dan ini adalah permainan zero-sum yang membuat orang lain kehilangan, dan apa yang membuat orang kehilangan lainnya. Setiap pedagang harus memasang modal untuk sisi perdagangan mereka. Pada contoh di atas, Anda membeli opsi di 44,50, dan seseorang menjual opsi itu kepada Anda. Resiko maksimum Anda adalah 44,50 jika opsi diendapkan di 0, oleh karena itu biaya perdagangan Anda 44,50. Orang yang menjual kepada Anda memiliki risiko maksimum 55,50 jika pilihannya mencapai 100 (100 - 44,50 55,50). Seorang pedagang dapat membeli beberapa kontrak, jika diinginkan. Contoh lain: NASDAQ US Tech 100 indeks gt 3,784 (11 a.m.). Tawaran dan penawaran saat ini masing-masing adalah 74,00 dan 80,00. Jika Anda berpikir indeks akan berada di atas 3.784 pukul 11 ​​pagi Anda membeli opsi biner di 80 (atau letakkan tawaran dengan harga lebih rendah dan berharap seseorang menjual kepada Anda dengan harga itu). Jika Anda berpikir indeks akan berada di bawah 3.784 pada saat itu, Anda menjual di 74.00 (atau memberi tawaran di atas harga itu dan berharap seseorang membelinya dari Anda). Anda memutuskan untuk menjual pada pukul 74.00, percaya bahwa indeks akan turun di bawah 3.784 (disebut strike price) pada pukul 11 ​​pagi. Dan jika Anda benar-benar menyukai perdagangan, Anda dapat menjual (atau membeli) beberapa kontrak. Gambar 1 menunjukkan perdagangan untuk menjual lima kontrak (ukuran) pada pukul 74.00. Platform Nadex secara otomatis menghitung kerugian dan keuntungan maksimal Anda saat Anda membuat pesanan, yang disebut tiket. Tiket Perdagangan Nadex dengan Max Profit dan Max Loss (Gambar 1) Keuntungan maksimum tiket ini adalah 370 (74 x 5 370), dan kerugian maksimumnya adalah 130 (100 - 74 26 x 5 130) berdasarkan lima kontrak dan penjualan Harga 74.00 (Untuk informasi lebih lanjut tentang topik ini, lihat Introduction to Binary Options) Bagaimana Tawaran dan Tuntutan Ditentukan Penawaran dan permintaan ditentukan oleh pedagang sendiri karena mereka menilai probabilitas proposisi itu benar atau tidak. Secara sederhana, jika tawaran dan permintaan pada opsi biner ada di 85 dan 89, maka trader mengasumsikan probabilitas yang sangat tinggi bahwa hasil opsi biner akan menjadi iya, dan opsi akan berakhir bernilai 100. Jika tawaran Dan bertanya mendekati 50, pedagang tidak yakin apakah biner akan berakhir pada 0 atau 100 peluangnya. Jika tawaran dan permintaan masing-masing pada tanggal 10 dan 15, yang mengindikasikan pedagang berpikir ada kemungkinan opsi yang tinggi tidak akan ada, dan akan berakhir bernilai 0. Pembeli di area ini bersedia mengambil risiko kecil untuk keuntungan besar. Sementara mereka menjual bersedia mengambil keuntungan kecil tapi sangat mungkin untuk risiko besar (relatif terhadap keuntungan mereka). Dimana Berdagang Pilihan Biner Opsi biner diperdagangkan di bursa Nadex. Pertukaran A.S. legal pertama berfokus pada opsi biner. Nadex menyediakan platform trading biner pilihan berbasis browser yang bisa diakses trader melalui akun demo atau live account. Platform perdagangan menyediakan grafik real-time bersamaan dengan akses pasar langsung ke harga opsi biner saat ini. Pilihan biner juga tersedia melalui Chicago Board Options Exchange (CBOE). Siapa saja yang memiliki akun pialang yang disetujui opsi dapat menukarkan opsi biner CBOE melalui akun perdagangan tradisional mereka. Tidak semua broker menyediakan trading option biner. Setiap kontrak Nadex diperdagangkan menelan biaya 0,90 untuk masuk dan 0,90 untuk keluar. Biaya dibatasi sekitar 9, jadi pembelian 15 lot masih akan dikenakan biaya 9 untuk masuk dan 9 untuk keluar. Jika Anda memegang perdagangan Anda sampai penyelesaian dan menyelesaikan uang, biaya yang harus dikeluarkan dinilai pada Anda pada saat kadaluwarsa. Jika Anda memegang perdagangan sampai penyelesaian, tapi kehabisan uang, tidak ada biaya perdagangan yang harus dikeluarkan dinilai. Pilihan biner CBOE diperdagangkan melalui berbagai pilihan broker masing-masing mengenakan biaya komisi sendiri. Pilih Pasar Biner Anda Beberapa kelas aset dapat diperdagangkan melalui opsi biner. Nadex menawarkan perdagangan di indeks utama seperti Dow 30 (Wall Street 30), SampP 500 (500 AS), Nasdaq 100 (US TECH 100) dan Russell 2000 (US Smallcap 2000). Indeks global untuk Inggris (FTSE 100), Jerman (Jerman 30) dan Jepang (Jepang 225) juga tersedia. Nadex menawarkan opsi biner komoditas terkait harga minyak mentah. Gas alam, emas, perak, tembaga, jagung dan kedelai. Acara berita perdagangan juga dimungkinkan dengan opsi biner acara. Opsi beli atau jual berdasarkan pada apakah Federal Reserve akan menaikkan atau menurunkan suku bunga, atau apakah klaim pengangguran dan gaji nonfarmasi akan datang di atas atau di bawah perkiraan konsensus. (Untuk informasi lebih lanjut tentang topik ini, lihat Pilihan Eksotik: Liburan Dari Perdagangan Biasa) CBOE menawarkan dua pilihan biner untuk perdagangan. Sebuah opsi Indeks SampP 500 (BSZ) berdasarkan Indeks SampP 500, dan opsi Indeks Volatilitas (BVZ) berdasarkan Indeks Volatilitas CBOE (VOC). Pilih Bingkai Waktu Anda Seorang pedagang dapat memilih dari opsi biner Nadex (di kelas aset di atas) yang akan berakhir setiap jam, harian atau mingguan. Pilihan per jam memberi kesempatan bagi pedagang hari. Bahkan dalam kondisi pasar yang tenang, untuk mencapai tingkat pengembalian yang mapan jika mereka benar dalam memilih arah pasar selama jangka waktu tersebut. Opsi harian akan berakhir pada akhir hari perdagangan, dan berguna bagi pedagang hari atau mereka yang ingin melakukan lindung nilai terhadap saham lain, saham, atau kepemilikan komoditas terhadap pergerakan hari itu. Opsi mingguan berakhir pada akhir minggu perdagangan, dan oleh karena itu diperdagangkan oleh pedagang ayun sepanjang minggu, dan juga oleh pedagang hari sebagai pilihan pendekatan kadaluarsa pada hari Jumat sore. Kontrak berbasis acara akan berakhir setelah rilis berita resmi yang terkait dengan acara tersebut, dan karena itu semua jenis pedagang mengambil posisi dengan baik sebelum - dan sampai pada saat kadaluwarsa. Keuntungan dan Kerugian Berbeda dengan pasar saham atau forex aktual di mana selisih harga atau selip dapat terjadi, risiko opsi biner dibatasi. Ini tidak mungkin untuk kehilangan lebih dari biaya perdagangan. Hasil yang lebih baik dari rata-rata juga dimungkinkan di pasar yang sangat sepi. Jika indeks saham atau pasangan forex hampir tidak bergerak, sulit untuk mendapatkan keuntungan, namun dengan opsi biner, pembayarannya diketahui. Jika Anda membeli opsi biner pada 20, maka akan beres pada 100 atau 0, membuat Anda 80 atas 20 investasi Anda atau kehilangan Anda 20. Ini adalah pahala rasio risiko 4: 1. Sebuah kesempatan yang tidak mungkin ditemukan di pasar sebenarnya yang mendasari opsi biner. Sisi lain dari ini adalah bahwa keuntungan Anda selalu dibatasi. Tidak peduli berapa banyak pasangan saham atau valas bergerak sesuai keinginan Anda, pilihan opsi biner yang paling banyak dapat bernilai adalah 100. Membeli beberapa kontrak pilihan merupakan salah satu cara untuk memperoleh keuntungan lebih banyak dari pergerakan harga yang diharapkan. Karena pilihan biner bernilai maksimal 100, itu membuat mereka dapat diakses oleh pedagang bahkan dengan modal perdagangan terbatas. Karena batas perdagangan hari bursa tradisional tidak berlaku. Perdagangan bisa dimulai dengan deposit 100 di Nadex. Pilihan biner adalah turunan berdasarkan aset dasar, yang tidak Anda miliki. Oleh karena itu, Anda tidak berhak mendapatkan hak suara atau dividen yang berhak Anda miliki jika Anda memiliki saham yang sebenarnya. Pilihan biner didasarkan pada proposisi ya atau tidak. Potensi keuntungan dan kerugian Anda ditentukan oleh harga beli atau harga jual Anda, dan apakah opsi berakhir bernilai 100 atau 0. Risiko dan imbalan keduanya dibatasi, dan Anda dapat keluar dari opsi kapan saja sebelum kadaluarsa untuk mengunci keuntungan atau mengurangi kerugian. Pilihan biner di dalam A.S diperdagangkan melalui bursa Nadex dan CBOE. Perusahaan asing yang meminta warga A.S. untuk memperdagangkan bentuk opsi biner mereka biasanya beroperasi secara ilegal. Perdagangan opsi biner memiliki penghalang rendah untuk masuk. Tapi hanya karena sesuatu yang sederhana tidak berarti akan mudah untuk menghasilkan uang dengan. Selalu ada orang lain di sisi lain perdagangan yang menganggap mereka benar dan salah. Hanya perdagangan dengan modal yang bisa Anda kehilangan, dan berdagang dengan akun demo agar benar-benar merasa nyaman dengan bagaimana opsi biner bekerja sebelum diperdagangkan dengan modal riil. Pilihan Opsi Perdagangan dengan Opsi IQ Apa opsi biner Pertama-tama, ini adalah online yang sangat menguntungkan Alat trading yang memungkinkan Anda untuk memperkirakan jumlah potensi keuntungan di muka. Perdagangan opsi biner dapat menghasilkan pendapatan yang besar dalam waktu sesingkat mungkin. Pedagang membeli opsi dengan harga yang telah ditentukan. Perdagangan online bisa menguntungkan jika trader benar mengidentifikasi pergerakan pasar. Keuntungan Binary Options Trading adalah area berisiko tinggi dimana Anda bisa melipatgandakan atau bahkan melipatgandakan modal Anda atau kehilangannya dalam beberapa menit. Pilihan biner memiliki beberapa kelebihan sehingga memungkinkan untuk mendapatkan keuntungan lebih dengan risiko yang dapat diramalkan. Pilihan dengan keuntungan tetap berbeda dari perdagangan konvensional. Pemula bisa memperdagangkan opsi biner dengan IQ Option sama seperti trader berpengalaman. Seluruh proses sepenuhnya otomatis. Pedagang opsi biner menyadari keuntungan mereka terlebih dahulu. Tujuan utamanya adalah memilih arah gerakan pasar yang benar. Mereka perlu memilih dua arah hanya atas atau bawah. Dua Jenis Perdagangan Online Platform Opsi IQ memungkinkan Anda untuk memperdagangkan opsi biner dalam dua mode dasar. Praktik akun adalah untuk pelatihan. Untuk membuka rekening praktek dan untuk menguji kekuatan Anda, Anda bahkan tidak perlu melakukan deposit. Untuk real trading, anda perlu deposit 10 saja. Ini memastikan bonus hingga 36. Saat membuka akun dengan jumlah yang lebih besar (dari 3.000), pengelola akun pribadi akan siap melayani Anda. Operasi perdagangan yang ditawarkan di situs ini dapat dianggap sebagai Operasi Perdagangan Berisiko tinggi dan pelaksanaannya bisa sangat berisiko. Membeli instrumen keuangan atau memanfaatkan layanan yang ditawarkan di situs web dapat mengakibatkan kerugian yang signifikan atau bahkan dalam kerugian total semua dana di akun Anda. Anda diberi hak non-eksklusif yang tidak dapat dialihkan terbatas untuk menggunakan IP yang ada di situs ini untuk tujuan pribadi dan nonkomersial sehubungan dengan layanan yang ditawarkan di Situs Web saja. Perusahaan bertindak di luar Federasi Rusia. Eu.iqoption dimiliki dan dioperasikan oleh Iqoption Europe Ltd. IQ Option, 20132017 Informasi pemulihan password berhasil dikirim ke surat Anda Pendaftaran saat ini tidak tersedia di Federasi Rusia. Jika Anda pikir Anda melihat pesan ini karena kesalahan, hubungi dukungan. Apa yang Baru Dengan Python 3.0 14 Februari 2009 Artikel ini menjelaskan fitur baru dengan Python 3.0, dibandingkan dengan 2.6. Python 3.0, yang juga dikenal sebagai 8220Python 30008221 atau 8220Py3K8221, adalah rilis Python yang pertama yang secara sukarela mundur. Ada lebih banyak perubahan daripada di rilis biasa, dan lebih penting bagi semua pengguna Python. Meski begitu, setelah mencerna perubahannya, Anda pasti tahu Python benar-benar tidak mengubah banyak dan lebih banyak lagi, kebanyakan memperbaiki gangguan dan kutil yang terkenal, dan menyingkirkan banyak cruft tua. Artikel ini tidak berusaha memberikan spesifikasi lengkap semua fitur baru, namun mencoba memberikan gambaran yang mudah. Untuk rincian lengkap, Anda harus mengacu pada dokumentasi untuk Python 3.0, dan jika banyak PEP yang dirujuk dalam teks. Jika Anda ingin memahami keseluruhan implementasi dan desain yang sesuai untuk fitur tertentu, PEP biasanya memiliki rincian lebih banyak daripada dokumentasi reguler namun perhatikan bahwa PEP biasanya tidak selalu diperbarui setelah fitur telah diterapkan sepenuhnya. Karena keterbatasan waktu dokumen ini tidak selengkap yang seharusnya. Seperti biasa untuk rilis baru, file MiscNEWS dalam distribusi sumber berisi banyak informasi terperinci tentang setiap hal kecil yang telah diubah. Common Stumbling Blocks Bagian ini mencantumkan beberapa perubahan yang kemungkinan besar akan mengantar Anda jika Anda terbiasa dengan Python 2.5. Print Is A Function Pernyataan cetak telah diganti dengan fungsi cetak (), dengan argumen kata kunci untuk menggantikan sebagian besar sintaks khusus dari pernyataan cetak lama (PEP 3105). Contoh: Anda juga dapat menyesuaikan pemisah antara item, misalnya: Fungsi cetak () tidak mendukung fitur 8220softspace8221 dari laporan cetak lama. Misalnya, dengan Python 2.x, print quotAnquot, quotBquot akan menulis quotAnBnquot namun dengan Python 3.0, print (quotAnquot, quotBquot) menulis quotAn Bnquot. Awalnya, Anda akan mendapati diri Anda mengetik cetak lama x banyak dalam mode interaktif. Waktu untuk melatih jari Anda untuk mengetikkan cetak (x) sebagai gantinya Saat menggunakan alat konversi sumber-ke-sumber 2to3, semua pernyataan cetak secara otomatis dikonversi menjadi cetak () pemanggilan fungsi, jadi ini sebagian besar bukan masalah untuk proyek yang lebih besar. Tampilan Dan Iterator Bukan Dari Daftar Beberapa API terkenal tidak lagi daftar kembali: metode dict dict.keys (). Dict.items () dan dict.values ​​() mengembalikan 8220views8221 alih-alih daftar. Misalnya, ini tidak lagi bekerja: k d.keys () k.sort (). Gunakan k diurutkan (d) sebagai gantinya (ini bekerja dengan Python 2.5 juga dan sama efisiennya). Juga, dict.iterkeys (). Metode dict.iteritems () dan dict.itervalues ​​() tidak lagi didukung. Map () dan filter () mengembalikan iterator. Jika Anda benar-benar membutuhkan daftar, perbaikan cepat adalah mis. Daftar (map (.)). Tapi perbaikan yang lebih baik seringkali menggunakan pemahaman daftar (terutama bila kode asli menggunakan lambda), atau menulis ulang kode sehingga tidak memerlukan daftar sama sekali. Yang sangat rumit adalah peta () dipanggil untuk efek samping dari fungsi transformasi yang benar adalah dengan menggunakan loop biasa (karena membuat daftar hanya akan sia-sia). Range () sekarang berperilaku seperti xrange () yang digunakan untuk berperilaku, kecuali bekerja dengan nilai ukuran sewenang-wenang. Yang terakhir ini sudah tidak ada lagi. Zip () sekarang mengembalikan sebuah iterator. Pengurutan Perbandingan Python 3.0 telah menyederhanakan peraturan untuk perbandingan pemesanan: Operator perbandingan pemesanan (lt. Gt. Gt) menaikkan pengecualian TypeError saat operan tidak memiliki pemesanan alam yang berarti. Jadi, ungkapan seperti 1 lt. 0 gt Tidak ada atau len lt len ​​sudah tidak berlaku lagi, dan mis. Tidak ada satu pun yang menimbulkan TypeError alih-alih mengembalikan False. Konsekuensinya adalah bahwa menyortir daftar heterogen tidak lagi masuk akal, semua elemen harus sebanding satu sama lain. Perhatikan bahwa ini tidak berlaku untuk operator dan operator: objek dari tipe yang tak tertandingi berbeda selalu membandingkan tidak sama satu sama lain. Builtin.sorted () dan list.sort () tidak lagi menerima argumen cmp yang memberikan fungsi perbandingan. Gunakan argumen kunci sebagai gantinya. N.B. Argumen kunci dan argumen terbalik sekarang adalah kata kunci-only8221. Fungsi cmp () harus diperlakukan sebagai hilang, dan metode khusus cmp () tidak lagi didukung. Gunakan lt () untuk menyortir, eq () dengan hash (). Dan perbandingan kaya lainnya sesuai kebutuhan. (Jika Anda benar-benar membutuhkan fungsi cmp (), Anda bisa menggunakan ungkapan (a gt b) - (a lt b) sebagai padanan untuk cmp (a, b).) PEP 0237. Intinya, lama berganti nama menjadi int. Artinya, hanya ada satu built-in tipe integral, bernama int tapi berperilaku kebanyakan seperti tipe lama. PEP 0238. Ekspresi seperti 12 mengembalikan pelampung. Gunakan 12 untuk mendapatkan perilaku truncating. (Sintaks yang terakhir telah ada selama bertahun-tahun, setidaknya sejak Python 2.2.) Konstanta sys.maxint telah dihapus, karena tidak ada lagi batasan nilai bilangan bulat. Namun, sys.maxsize dapat digunakan sebagai integer yang lebih besar daripada daftar praktis atau indeks string. Ini sesuai dengan ukuran integer 8216natural8221 yang berlaku dan biasanya sama dengan sys.maxint pada rilis sebelumnya pada platform yang sama (dengan asumsi opsi build yang sama). Repr () dari sebuah integer panjang tidak termasuk L trailing lagi, jadi kode yang tanpa syarat memiliki karakter yang akan memotong angka terakhir. (Gunakan str () sebagai gantinya.) Literal Oktober tidak lagi berbentuk 0720 menggunakan 0o720 sebagai gantinya. Teks Vs. Data bukan Unicode Vs. 8-bit Segala sesuatu yang Anda pikir Anda tahu tentang data biner dan Unicode telah berubah. Python 3.0 menggunakan konsep teks dan (biner) data, bukan string Unicode dan string 8-bit. Semua teks Unicode namun dikodekan Unicode direpresentasikan sebagai data biner. Tipe yang digunakan untuk menahan teks adalah str. Tipe yang digunakan untuk menyimpan data adalah byte. Perbedaan terbesar dengan situasi 2.x adalah bahwa setiap usaha untuk mencampur teks dan data dengan Python 3.0 meningkatkan TypeError. Sedangkan jika Anda mencampur Unicode dan string 8-bit dengan Python 2.x, itu akan berhasil jika string 8-bit terjadi hanya mengandung byte 7-bit (ASCII), tapi Anda akan mendapatkan UnicodeDecodeError jika berisi non-ASCII Nilai. Perilaku spesifik nilai ini telah menyebabkan banyak wajah sedih selama bertahun-tahun. Sebagai konsekuensi dari perubahan filosofi ini, hampir semua kode yang menggunakan Unicode, pengkodean atau data biner kemungkinan besar harus berubah. Perubahannya menjadi lebih baik, seperti di dunia 2.x ada banyak bug yang berhubungan dengan pencampuran teks yang dikodekan dan tidak terdefinisi. Untuk dipersiapkan dengan Python 2.x, mulailah menggunakan unicode untuk semua teks yang tidak terenkripsi, dan str untuk data biner atau encoded saja. Kemudian alat 2to3 akan melakukan sebagian besar pekerjaan untuk Anda. Anda tidak bisa lagi menggunakan uquot. Quot literal untuk teks Unicode Namun, Anda harus menggunakan bquot. Quot literal untuk data biner Sebagai str dan byte jenis tidak dapat dicampur, Anda harus selalu secara eksplisit mengkonversi antara mereka. Gunakan str.encode () untuk beralih dari str ke byte. Dan bytes.decode () untuk beralih dari byte ke str. Anda juga dapat menggunakan byte (s, encoding.) Dan str (b, encoding.). Masing-masing. Seperti str. Jenis byte tidak dapat diubah. Ada tipe mutable yang terpisah untuk menampung data biner buffer, bytearray. Hampir semua API yang menerima byte juga menerima bytearray. API yang bisa berubah didasarkan pada koleksi. Mungkin. Semua garis miring terbalik dalam string mentah literal ditafsirkan secara harfiah. Ini berarti bahwa U dan u lolos dengan senar mentah tidak diperlakukan secara khusus. Sebagai contoh, ru20ac adalah string 6 karakter dengan Python 3.0, sedangkan pada 2.6, uru20ac adalah karakter tunggal 8220euro8221. (Tentu saja, perubahan ini hanya akan mempengaruhi string mentah literal karakter euro di Python 3.0.) Tipe abstraksi bawaan builtin telah dihapus. Gunakan str sebagai gantinya. Jenis str dan byte tidak memiliki fungsionalitas yang cukup untuk menjamin kelas dasar bersama. Alat 2to3 (lihat di bawah) menggantikan setiap kejadian basestring dengan str. File dibuka sebagai file teks (masih mode default untuk open ()) selalu menggunakan encoding untuk memetakan antar string (dalam memori) dan byte (pada disk). File biner (dibuka dengan huruf b pada argumen mode) selalu menggunakan byte dalam memori. Ini berarti bahwa jika sebuah file dibuka dengan menggunakan mode atau pengkodean yang salah, IO kemungkinan akan gagal keras, alih-alih menghasilkan data yang tidak benar. Ini juga berarti bahwa bahkan pengguna Unix harus menentukan mode yang benar (teks atau biner) saat membuka file. Ada pengkodean default yang bergantung pada platform, yang pada platform Unixy dapat diatur dengan variabel lingkungan LANG (dan terkadang juga dengan beberapa variabel lingkungan spesifik lokal platform lainnya). Dalam banyak kasus, tapi tidak semua, default sistemnya adalah UTF-8 Anda seharusnya tidak mengandalkan default ini. Setiap aplikasi membaca atau menulis lebih dari teks ASCII murni mungkin harus memiliki cara untuk mengganti pengkodean. Tidak ada lagi kebutuhan untuk menggunakan stream encoding-aware pada modul codec. Nama file dikirimkan ke dan dikembalikan dari API sebagai string (Unicode). Hal ini dapat menghadirkan masalah khusus pada platform karena pada beberapa platform, nama file adalah string byte yang sewenang-wenang. (Di sisi lain, pada nama file Windows secara native disimpan sebagai Unicode.) Sebagai karya-sekitar, sebagian besar API (misalnya open () dan banyak fungsi dalam modul os) yang mengambil nama file menerima objek byte serta string, dan sebuah Beberapa API memiliki cara untuk meminta nilai kembali byte. Jadi, os.listdir () mengembalikan daftar contoh byte jika argumennya adalah contoh byte, dan os.getcwdb () mengembalikan direktori kerja saat ini sebagai contoh byte. Perhatikan bahwa ketika os.listdir () mengembalikan daftar string, nama file yang tidak dapat diterjemahkan dengan benar dihilangkan daripada menaikkan UnicodeError. Beberapa sistem API seperti os.environ dan sys.argv juga dapat menghadirkan masalah saat byte yang tersedia oleh sistem tidak dapat ditafsirkan menggunakan pengkodean default. Mengatur variabel LANG dan rerunning program mungkin adalah pendekatan terbaik. PEP 3138. Repr () string tidak lagi lolos karakter non-ASCII. Ini masih lolos dari karakter kontrol dan kode poin dengan status yang tidak dapat dicetak dalam standar Unicode. PEP 3120. Encoding sumber default sekarang UTF-8. PEP 3131. Surat-surat non-ASCII sekarang diperbolehkan dalam pengenal. (Namun, perpustakaan standar tetap ASCII-hanya dengan pengecualian nama kontributor dalam komentar.) Modul StringIO dan cStringIO telah hilang. Sebagai gantinya, impor modul io dan gunakan io.StringIO atau io.BytesIO untuk teks dan data masing-masing. Lihat juga Unicode HOWTO. Yang telah diperbarui untuk Python 3.0. Ikhtisar Perubahan Sintaks Bagian ini memberikan gambaran singkat tentang setiap perubahan sintaksis dengan Python 3.0. Sintaks Baru PEP 3107. Argumen fungsi dan anotasi nilai kembali. Ini menyediakan cara standar untuk menganotasi parameter dan nilai pengembalian fungsional. Tidak ada semantik yang melekat pada anotasi tersebut kecuali bahwa mereka dapat di introspeksi saat runtime menggunakan atribut anotasi. Tujuannya adalah untuk mendorong eksperimen melalui metaclasses, dekorator atau kerangka kerja. PEP 3102. Argumen hanya kata kunci Dinamai parameter yang terjadi setelah args dalam daftar parameter harus ditentukan menggunakan sintaks kata kunci dalam panggilan. Anda juga dapat menggunakan daftar parameter yang kosong untuk menunjukkan bahwa Anda tidak menerima daftar argumen panjang variabel, namun Anda memiliki argumen kata kunci saja. Argumen kata kunci diperbolehkan setelah daftar kelas dasar dalam definisi kelas. Ini digunakan oleh konvensi baru untuk menentukan metaclass (lihat bagian berikutnya), namun dapat digunakan untuk tujuan lain juga, selama metaclass mendukungnya. PEP 3104. Pernyataan nonlokalisasi Menggunakan nonlocal x Anda sekarang dapat menetapkan secara langsung ke variabel di lingkup luar (tapi non-global). Nonlocal adalah kata yang baru dicadangkan. PEP 3132. Extended Iterable Unpacking. Anda sekarang bisa menulis hal-hal seperti a, b, rest somquiting. Dan bahkan istirahat, barang. Benda sisa selalu berupa daftar (mungkin kosong) sisi kanan mungkin ada yang tertahankan. Contoh: Kamus comprehensions: berarti hal yang sama seperti dict (barang) namun lebih fleksibel. (Ini adalah PEP 0274 yang dibenarkan.) Setel literal, mis. . Perhatikan bahwa kamus kosong menggunakan set () untuk kumpulan kosong. Set comprehensions juga didukung mis. Berarti hal yang sama seperti set (barang) tapi lebih fleksibel. Huruf oktal baru, mis. 0o720 (sudah di 2.6). Literal oktal tua (0720) hilang. Literal biner baru, mis. 0b1010 (sudah di 2.6), dan ada fungsi builtin yang baru, bin (). Bytes literal diperkenalkan dengan b atau B terkemuka. Dan ada fungsi builtin yang sesuai, bytes (). Berubah Sintaks sebagai dan dengan sekarang kata-kata reserved. (Sejak 2.6, sebenarnya.) Benar. Salah . Dan tidak ada kata-kata yang dicadangkan. (2.6 memberlakukan sebagian pembatasan terhadap None.) PEP 3115. Sintaks Metakel Baru Alih-alih: Anda sekarang harus menggunakan: Variabel metaclass modul-global tidak lagi didukung. (Ini adalah penopang agar lebih mudah default ke kelas gaya baru tanpa menurunkan setiap kelas dari objek.) Pemahaman daftar tidak lagi mendukung bentuk sintaksis. Untuk var di item1. Item2 . Gunakan. Untuk var in (item1. Item2.) Sebagai gantinya. Juga perhatikan bahwa pemahaman daftar memiliki semantik yang berbeda: mereka mendekati gula sintaksis untuk ekspresi generator di dalam daftar () konstruktor, dan khususnya variabel kontrol loop tidak lagi bocor ke dalam lingkup sekitarnya. The elipsis (.) Dapat digunakan sebagai ekspresi atom di mana saja. (Sebelumnya itu hanya diperbolehkan dalam irisan.) Juga, sekarang harus dieja sebagai. . (Sebelumnya juga bisa dibilang sebagai akibat dari tata bahasa saja.) Sintaks yang Dihapus PEP 3113. Parameter tuang unpacking dihapus. Anda tidak bisa lagi menulis def foo (a, (b, c)). . Gunakan def foo (a, bc): b, c bc sebagai gantinya. Removeticks yang dihapus (gunakan repr () sebagai gantinya). Dihapus ltgt (gunakan sebagai gantinya). Kata kunci yang dihapus: exec () bukan lagi kata kunci yang tersisa sebagai fungsi. (Untungnya sintaks fungsi juga diterima di 2.x.) Perhatikan juga bahwa exec () tidak lagi mengambil argumen stream daripada exec (f) Anda bisa menggunakan exec (f.read ()). Integer literal tidak lagi mendukung trailing l atau L. String literal tidak lagi mendukung u atau U terkemuka. Sintaks impor dari modul hanya diizinkan di tingkat modul, tidak lagi di dalam fungsi. Satu-satunya sintaks yang dapat diterima untuk impor relatif berasal. Nama impor modul Semua formulir impor tidak dimulai dengan. Ditafsirkan sebagai impor absolut. (PEP 0328) Kelas klasik hilang. Perubahan Sudah Hadir Dengan Python 2.6 Karena banyak pengguna mungkin membuat lompatan langsung dari Python 2.5 ke Python 3.0, bagian ini mengingatkan pembaca akan fitur baru yang pada awalnya dirancang untuk Python 3.0 namun dikirim kembali ke Python 2.6. Bagian yang sesuai pada What8217s New dengan Python 2.6 harus dikonsultasikan untuk deskripsi yang lebih panjang. PEP 343: Pernyataan 8216with8217. Pernyataan itu sekarang menjadi fitur standar dan tidak perlu lagi diimpor dari masa depan. Juga periksa Writing Context Managers dan modul contextlib. PEP 366: Impor Relatif Eksplisit Dari Modul Utama. Ini meningkatkan kegunaan opsi -m saat modul referensi hidup dalam sebuah paket. PEP 370: Direktori situs per-pengguna. PEP 371: Paket multiprosesor. PEP 3101: Format String Lanjutan. Catatan: deskripsi 2.6 menyebutkan format () metode untuk string 8-bit dan Unicode. Di 3.0, hanya tipe str (string teks dengan dukungan Unicode) mendukung metode ini yang tipe bytenya tidak. Rencananya adalah untuk membuat satu-satunya API untuk pemformatan string, dan untuk mulai mencela operator dengan Python 3.1. PEP 3105: cetak Sebagai Fungsi. Ini sekarang menjadi fitur standar dan tidak lagi perlu diimpor dari masa depan. Rincian lebih lanjut diberikan di atas. PEP 3110: Perubahan Penanganan Pengecualian. Skrip kecuali exc sebagai var sekarang standar dan kecuali exc. Var tidak lagi didukung (Tentu saja, bagian var masih opsional.) PEP 3112: Byte Literals. Bquot Quot string literal notasi (dan variannya seperti bquotquotquot quotquotquot dan brquot quot quot) sekarang menghasilkan literal tipe byte. PEP 3116: Perpustakaan IO Baru. Modul io sekarang menjadi standar cara melakukan file IO, dan nilai awal sys.stdin. Sys.stdout dan sys.stderr sekarang merupakan instance dari io.TextIOBase. Fungsi builtin open () sekarang menjadi alias untuk io.open () dan memiliki pengkodean kata kunci tambahan. Kesalahan Newline dan closefd Perhatikan juga bahwa argumen mode tidak valid sekarang meningkatkan ValueError. Bukan IOError. Objek file biner yang mendasari objek file teks dapat diakses sebagai f.buffer (tapi hati-hati bahwa objek teks menyimpan buffer itu sendiri untuk mempercepat operasi pengkodean dan penguraian). PEP 3118: Protokol Buffer Revisi. Buffer builtin lama () sekarang benar-benar hilang memoryview builtin yang baru () menyediakan (sebagian besar) fungsi serupa. PEP 3119: Kelas Dasar Abstrak. Modul abc dan ABC yang didefinisikan dalam modul koleksi memainkan peran yang agak menonjol dalam bahasa sekarang, dan tipe koleksi builtin seperti dict dan daftar sesuai dengan koleksi.MutableMapping and collections.MutableSequence ABCs, masing-masing. PEP 3127: Dukungan Literal dan Sintaks Integer. Seperti disebutkan di atas, notasi literal oktal baru adalah satu-satunya yang didukung, dan literal biner telah ditambahkan. PEP 3129: Dekorator Kelas. PEP 3141: Hirarki Tipe untuk Angka. Modul angka adalah penggunaan baru ABC lainnya, yang menentukan menara 8220numerik Python821798281. Perhatikan juga modul pecahan baru yang mengimplementasikan angka. Perubahan Perpustakaan Karena kendala waktu, dokumen ini tidak secara mendalam membahas perubahan yang sangat luas pada perpustakaan standar. PEP 3108 adalah rujukan untuk perubahan besar pada perpustakaan. Berikut review kapsul: Banyak modul tua telah dihapus. Beberapa, seperti gopherlib (tidak lagi digunakan) dan md5 (diganti dengan hashlib), sudah tidak berlaku lagi oleh PEP 0004. Yang lainnya dikeluarkan sebagai akibat dari penghapusan dukungan untuk berbagai platform seperti Irix, BeOS dan Mac OS 9 (lihat PEP 0011). Beberapa modul juga dipilih untuk dihapus dengan Python 3.0 karena kurangnya penggunaan atau karena penggantian yang lebih baik ada. Lihat PEP 3108 untuk daftar lengkap. Paket bsddb3 telah dihapus karena kehadirannya di perpustakaan standar inti telah membuktikan dari waktu ke waktu untuk menjadi beban khusus bagi pengembang inti karena ketidakstabilan pengujian dan jadwal rilis Berkeley DB8217. Namun, paket itu masih hidup dan sehat, dikelola secara eksternal di jcea.esprogramacionpybsddb.htm. Beberapa modul diganti namanya karena nama lama mereka tidak mematuhi PEP 0008. Atau karena berbagai alasan lainnya. Berikut adalah daftar: Pola umum pada Python 2.x adalah memiliki satu versi modul yang diimplementasikan dengan Python murni, dengan versi akselerasi opsional yang diimplementasikan sebagai ekstensi C misalnya, acar dan cPickle. Ini menempatkan beban untuk mengimpor versi yang dipercepat dan jatuh kembali pada versi Python murni pada setiap pengguna modul ini. Dengan Python 3.0, versi yang dipercepat dianggap sebagai rincian implementasi versi Python murni. Pengguna harus selalu mengimpor versi standar, yang mencoba mengimpor versi yang dipercepat dan kembali ke versi Python murni. Pasangan cPickle acar menerima perawatan ini. Modul profil ada pada daftar 3.1. Modul StringIO telah diubah menjadi kelas dalam modul io. Beberapa modul terkait telah dikelompokkan ke dalam paket, dan biasanya nama submodule telah disederhanakan. Paket baru yang dihasilkan adalah: dbm (anydbm. Dbhash dbm. Dumbdbm. Gdbm. Whichdb). Html (HTMLParser. Htmlentitydefs). Http (httplib. BaseHTTPServer. CGIHTTPServer. SimpleHTTPServer. Cookie. Cookielib). Tkinter (semua modul yang berhubungan dengan Tkinter kecuali kura-kura). Si sasaran penyu tidak benar-benar peduli dengan tkinter. Perhatikan juga bahwa seperti pada Python 2.6, fungsi kura-kura telah sangat ditingkatkan. Urllib (urllib, urllib2, urlparse, robotparse). Xmlrpc (xmlrpclib. DocXMLRPCServer. SimpleXMLRPCServer). Beberapa perubahan lain pada modul perpustakaan standar, tidak tercakup dalam PEP 3108: Setan yang Dibunuh. Gunakan fungsi builtin set (). Pembersihan modul sys: remove sys.exitfunc (). Sys.excclear (). Sys.exctype Sys.excvalue Sys.exctraceback (Perhatikan bahwa sys.lasttype dan lain-lain tetap ada.) Pembersihan tipe array.array: metode read () dan write () hilang gunakan fromfile () dan tofile () sebagai gantinya. Juga, typecode c untuk array hilang 8211 menggunakan b untuk byte atau u untuk karakter Unicode. Pembersihan modul operator: urutan yang dihapusIncludes () dan isCallable (). Pembersihan modul benang: acquirelock () dan releaselock () hilang gunakan acquisition () dan release () sebagai gantinya. Pembersihan modul acak: hapus API jumpahead (). Modul baru hilang Fungsi os.tmpnam (). Os.tempnam () dan os.tmpfile () telah dihapus untuk mendukung modul tempfile. Modul tokenize telah diubah untuk bekerja dengan byte. Titik masuk utama sekarang tokenize.tokenize (). Bukannya generatetokens. String.letters dan teman-temannya (string.lowercase dan string.uppercase) hilang. Gunakan string.asciiletters dll sebagai gantinya. (Alasan untuk menghapusnya adalah string.letters dan teman-temannya memiliki perilaku spesifik lokal, yang merupakan ide buruk untuk kelas 8220constants8221 global yang menarik seperti itu.) Mengganti nama modul yang dibangun ke builtins (menyingkirkan garis bawah, menambahkan 8216s8217). Variabel builtins yang ditemukan di sebagian besar ruang nama global tidak berubah. Untuk memodifikasi builtin, Anda harus menggunakan builtins. Bukan builtins PEP 3101. Pendekatan Baru Untuk Memformat String Sebuah sistem baru untuk operasi pemformatan string built-in menggantikan operator pemformatan string. (Namun, operator masih didukung maka akan tidak berlaku lagi pada Python 3.1 dan dihapus dari bahasa di lain waktu.) Baca PEP 3101 untuk sendok penuh. Perubahan Pengecualian API untuk meningkatkan dan menangkap pengecualian telah dibersihkan dan fitur kuat baru ditambahkan: PEP 0352. Semua pengecualian harus diturunkan (secara langsung atau tidak langsung) dari BaseException. Ini adalah akar dari hirarki pengecualian. Ini bukan baru sebagai rekomendasi, tapi persyaratan untuk mewarisi dari BaseException itu baru. (Python 2.6 masih mengizinkan kelas klasik untuk dinaikkan, dan tidak membatasi apa yang bisa Anda ambil.) Sebagai konsekuensinya, pengecualian string akhirnya benar-benar dan benar-benar mati. Hampir semua pengecualian benar-benar berasal dari Exception BaseException seharusnya hanya digunakan sebagai kelas dasar untuk pengecualian yang seharusnya hanya ditangani di tingkat atas, seperti SystemExit atau KeyboardInterrupt. Ungkapan yang dianjurkan untuk menangani semua pengecualian kecuali untuk kategori yang terakhir ini adalah menggunakan pengecualian kecuali pengecualian. StandardError telah dihapus (di 2.6 sudah). Pengecualian tidak lagi berperilaku seperti urutan. Gunakan atribut args sebagai gantinya. PEP 3109. Meningkatkan pengecualian. Anda sekarang harus menggunakan kenaikan Exception (args) daripada menaikkan Exception. Args Selain itu, Anda tidak lagi dapat secara eksplisit menentukan traceback sebagai gantinya, jika Anda harus melakukan ini, Anda dapat menetapkan langsung ke atribut traceback (lihat di bawah). PEP 3110. Menangkap pengecualian. Anda sekarang harus menggunakan kecuali SomeException sebagai variabel, bukan kecuali SomeException. variabel . Selain itu, variabel tersebut secara eksplisit dihapus saat blok kecuali dibiarkan. PEP 3134. Eksepsi merantai. Ada dua kasus: chaining implisit dan chaining eksplisit. Chaining implisit terjadi saat pengecualian diajukan di blok kecuali atau pawang. Hal ini biasanya terjadi karena bug di blok handler kita sebut ini sebagai pengecualian sekunder. Dalam kasus ini, pengecualian asli (yang sedang ditangani) disimpan sebagai atribut konteks pengecualian sekunder. Explaining chaining dipanggil dengan sintaks ini: (dimana primaryexception adalah ekspresi yang menghasilkan objek pengecualian, mungkin pengecualian yang sebelumnya tertangkap). Dalam kasus ini, pengecualian utama disimpan pada atribut penyebab pengecualian sekunder. Traceback yang dicetak saat pengecualian yang tidak tertangani terjadi pada rantai atribut penyebab dan konteks dan mencetak traceback terpisah untuk setiap komponen rantai, dengan pengecualian utama di bagian atas. (Pengguna Java mungkin mengenali perilaku ini.) PEP 3134. Benda pengecualian sekarang menyimpan traceback mereka sebagai atribut traceback. Ini berarti bahwa objek pengecualian sekarang berisi semua informasi yang berkaitan dengan pengecualian, dan ada sedikit alasan untuk menggunakan sys.excinfo () (meskipun yang terakhir tidak dihapus). Beberapa pesan pengecualian diperbaiki saat Windows gagal memuat modul ekstensi. Sebagai contoh, kode kesalahan 193 sekarang 1 bukan aplikasi Win32 yang valid. String sekarang berurusan dengan lokal non-Inggris. Miscellaneous Other Changes Operator dan Metode Khusus sekarang mengembalikan kebalikan dari. Kecuali jika tidak dipulihkan. Konsep metode 8220unbound8221 telah dihapus dari bahasa. Ketika referensi metode sebagai atribut kelas, Anda sekarang mendapatkan objek fungsi polos. Getlice (). Setlice () dan delslice () terbunuh. Sintaksnya ai: j sekarang diterjemahkan menjadi a.getitem (slice (i, j)) (atau setitem () atau delitem () bila digunakan sebagai target penugasan atau penghapusan). PEP 3114. Metode standar next () telah diganti namanya menjadi next (). Metode khusus okt () dan hex () dihapus 8211 oct () dan hex () menggunakan indeks () sekarang untuk mengubah argumen menjadi bilangan bulat. Dukungan yang dihapus untuk anggota dan metode. Atribut fungsi bernama funcX telah diubah namanya untuk menggunakan bentuk X, membebaskan nama-nama ini di dalam namespace atribut fungsi untuk atribut yang ditentukan pengguna. Untuk kecerdasan, pengabdian. Funccode Funcdefaults Funcdict Funcdoc Funcglobals Funcname diubah namanya menjadi ditutup. Kode. Default. Dict Dok. Dunia global Nama. Masing-masing. Bukan nol () sekarang bool (). PEP 3135. Baru super (). Anda sekarang dapat memanggil super () tanpa argumen dan (dengan asumsi ini adalah metode contoh reguler yang didefinisikan di dalam pernyataan kelas), kelas dan contoh yang benar akan dipilih secara otomatis. Dengan argumen, perilaku super () tidak berubah. PEP 3111. Rawinput () diganti namanya menjadi input (). Artinya, fungsi input baru () membaca sebuah baris dari sys.stdin dan mengembalikannya dengan baris baru trailing yang dilucuti. Ini menimbulkan EOFError jika input dihentikan sebelum waktunya. Untuk mendapatkan perilaku lama masukan (). Gunakan eval (input ()). Sebuah builtin baru berikutnya () ditambahkan untuk memanggil metode berikutnya () pada sebuah objek. Maju magang () ke sys.intern (). Dihapus: apply (). Alih-alih menerapkan (f, args) gunakan f (args). Dihapus callable (). Alih-alih callable (f) Anda bisa menggunakan hasattr (f, call). Fungsi operator.isCallable () juga hilang. Dihapus memaksa (). Fungsi ini tidak lagi melayani tujuan sekarang karena kelas klasik telah hilang. Menghapus execfile (). Alih-alih execfile (fn) gunakan exec (open (fn) .read ()). File yang dihapus Gunakan open (). Removed reduce (). Gunakan functools.reduce () jika Anda benar-benar membutuhkannya, 99 persen waktu yang eksplisit untuk loop lebih mudah dibaca. Reload dihapus (). Gunakan imp.reload (). Dihapus Dict.haskey () 8211 menggunakan operator. Perubahan API Bangun dan C Karena keterbatasan waktu, berikut adalah daftar perubahan API C yang tidak lengkap. Dukungan untuk beberapa platform dijatuhkan, termasuk namun tidak terbatas pada Mac OS 9, BeOS, RISCOS, Irix, dan Tru64. PEP 3118. API Buffer Baru PEP 3121. Modul Ekstensi Inisialisasi amp Finalisasi. PEP 3123. Membuat PyObjectHEAD sesuai dengan standar C. Tidak ada lagi dukungan API C untuk eksekusi terbatas. PyNumberCoerce. PyNumberCoerceEx. PyMemberGet. Dan PyMemberSet C API dihapus. Baru C API PyImportImportModuleNoBlock. Bekerja seperti PyImportImportModule tapi menang di blok kunci impor (mengembalikan kesalahan sebagai gantinya). Berganti nama menjadi boolean conversion C-level slot dan metode: nbnonzero sekarang nbbool. Dihapus METHOLDARGS dan WITHCYCLEGC dari API C. Kinerja Hasil bersih dari generalisasi 3.0 adalah bahwa Python 3.0 menjalankan patokan poket sekitar 10 lebih lambat dari pada Python 2.5. Kemungkinan besar penyebab terbesar adalah penghapusan casing khusus untuk bilangan bulat kecil. Ruang untuk perbaikan, tapi itu akan terjadi setelah 3.0 diluncurkan Porting To Python 3.0 Untuk memetakan kode sumber Python 2.5 atau 2.6 yang ada ke Python 3.0, strategi terbaik adalah sebagai berikut: (Prasyarat :) Mulailah dengan cakupan pengujian yang bagus. Port ke Python 2.6. Ini seharusnya tidak lebih bekerja daripada port rata-rata dari Python 2.x ke Python 2. (x1). Pastikan semua tes Anda lulus. (Masih menggunakan 2.6 :) Nyalakan switch baris perintah -3. Hal ini memungkinkan peringatan tentang fitur yang akan dihapus (atau diubah) di 3.0. Jalankan test suite Anda lagi, dan perbaiki kode yang Anda dapatkan peringatan sampai tidak ada peringatan tersisa, dan semua tes Anda masih berlalu. Jalankan penerjemah source-to-source 2to3 di atas pohon kode sumber Anda. (Lihat 2to3 - Python otomatis 2 sampai 3 terjemahan kode untuk lebih banyak tentang alat ini.) Jalankan hasil terjemahan di bawah Python 3.0. Perbaiki secara manual masalah yang tersisa, perbaiki masalah sampai semua tes berlalu lagi. Hal ini tidak dianjurkan untuk mencoba menulis kode sumber yang berjalan tidak berubah di bawah kedua Python 2.6 dan 3.0 you8217d harus menggunakan gaya pengkodean yang sangat beragam, mis. Menghindari pernyataan cetak, metaclasses, dan banyak lagi. Jika Anda memelihara sebuah perpustakaan yang perlu mendukung Python 2.6 dan Python 3.0, pendekatan terbaik adalah memodifikasi langkah 3 di atas dengan mengedit versi 2.6 dari kode sumber dan menjalankan penerjemah 2to3 lagi, daripada mengedit versi 3.0 dari Kode sumber. Untuk porting ekstensi C ke Python 3.0, silakan lihat Porting Extension Modules to 3.0 .16.2. Io 8212 Alat inti untuk bekerja dengan arus 16.2.1. Ikhtisar Modul io menyediakan fasilitas utama Python8217s untuk menangani berbagai jenis IO. Ada tiga jenis utama IO: teks IO. IO biner dan IO mentah. Ini adalah kategori generik, dan berbagai toko pendukung dapat digunakan untuk masing-masing. Benda beton milik salah satu kategori ini disebut objek file. Other common terms are stream and file-like object . Independently of its category, each concrete stream object will also have various capabilities: it can be read-only, write-only, or read-write. It can also allow arbitrary random access (seeking forwards or backwards to any location), or only sequential access (for example in the case of a socket or pipe). All streams are careful about the type of data you give to them. For example giving a str object to the write() method of a binary stream will raise a TypeError. So will giving a bytes object to the write() method of a text stream. Changed in version 3.3: Operations that used to raise IOError now raise OSError. since IOError is now an alias of OSError . 16.2.1.1. Text IO Text IO expects and produces str objects. This means that whenever the backing store is natively made of bytes (such as in the case of a file), encoding and decoding of data is made transparently as well as optional translation of platform-specific newline characters. The easiest way to create a text stream is with open(). optionally specifying an encoding: In-memory text streams are also available as StringIO objects: The text stream API is described in detail in the documentation of TextIOBase . 16.2.1.2. Binary IO Binary IO (also called buffered IO ) expects bytes-like objects and produces bytes objects. No encoding, decoding, or newline translation is performed. This category of streams can be used for all kinds of non-text data, and also when manual control over the handling of text data is desired. The easiest way to create a binary stream is with open() with b in the mode string: In-memory binary streams are also available as BytesIO objects: The binary stream API is described in detail in the docs of BufferedIOBase . Other library modules may provide additional ways to create text or binary streams. See socket.socket.makefile() for example. 16.2.1.3. Raw IO Raw IO (also called unbuffered IO ) is generally used as a low-level building-block for binary and text streams it is rarely useful to directly manipulate a raw stream from user code. Nevertheless, you can create a raw stream by opening a file in binary mode with buffering disabled: The raw stream API is described in detail in the docs of RawIOBase . 16.2.2. High-level Module Interface An int containing the default buffer size used by the module8217s buffered IO classes. open() uses the file8217s blksize (as obtained by os.stat() ) if possible. This is an alias for the builtin open() function. exception io. BlockingIOError This is a compatibility alias for the builtin BlockingIOError exception. exception io. UnsupportedOperation An exception inheriting OSError and ValueError that is raised when an unsupported operation is called on a stream. 16.2.2.1. In-memory streams It is also possible to use a str or bytes-like object as a file for both reading and writing. For strings StringIO can be used like a file opened in text mode. BytesIO can be used like a file opened in binary mode. Both provide full read-write capabilities with random access. 16.2.3. Class hierarchy The implementation of IO streams is organized as a hierarchy of classes. First abstract base classes (ABCs), which are used to specify the various categories of streams, then concrete classes providing the standard stream implementations. The abstract base classes also provide default implementations of some methods in order to help implementation of concrete stream classes. For example, BufferedIOBase provides unoptimized implementations of readinto() and readline() . At the top of the IO hierarchy is the abstract base class IOBase. It defines the basic interface to a stream. Note, however, that there is no separation between reading and writing to streams implementations are allowed to raise UnsupportedOperation if they do not support a given operation. The RawIOBase ABC extends IOBase. It deals with the reading and writing of bytes to a stream. FileIO subclasses RawIOBase to provide an interface to files in the machine8217s file system. The BufferedIOBase ABC deals with buffering on a raw byte stream ( RawIOBase ). Its subclasses, BufferedWriter. BufferedReader. and BufferedRWPair buffer streams that are readable, writable, and both readable and writable. BufferedRandom provides a buffered interface to random access streams. Another BufferedIOBase subclass, BytesIO. is a stream of in-memory bytes. The TextIOBase ABC, another subclass of IOBase. deals with streams whose bytes represent text, and handles encoding and decoding to and from strings. TextIOWrapper. which extends it, is a buffered text interface to a buffered raw stream ( BufferedIOBase ). Finally, StringIO is an in-memory stream for text. Argument names are not part of the specification, and only the arguments of open() are intended to be used as keyword arguments. The following table summarizes the ABCs provided by the io module: 16.2.3.1. IO Base Classes The abstract base class for all IO classes, acting on streams of bytes. There is no public constructor. This class provides empty abstract implementations for many methods that derived classes can override selectively the default implementations represent a file that cannot be read, written or seeked. Even though IOBase does not declare read(). readinto(). or write() because their signatures will vary, implementations and clients should consider those methods part of the interface. Also, implementations may raise a ValueError (or UnsupportedOperation ) when operations they do not support are called. The basic type used for binary data read from or written to a file is bytes. Other bytes-like objects are accepted as method arguments too. In some cases, such as readinto(). a writable object such as bytearray is required. Text IO classes work with str data. Note that calling any method (even inquiries) on a closed stream is undefined. Implementations may raise ValueError in this case. IOBase (and its subclasses) supports the iterator protocol, meaning that an IOBase object can be iterated over yielding the lines in a stream. Lines are defined slightly differently depending on whether the stream is a binary stream (yielding bytes), or a text stream (yielding character strings). See readline() below. IOBase is also a context manager and therefore supports the with statement. In this example, file is closed after the with statement8217s suite is finished8212even if an exception occurs: IOBase provides these data attributes and methods: Flush and close this stream. This method has no effect if the file is already closed. Once the file is closed, any operation on the file (e.g. reading or writing) will raise a ValueError . As a convenience, it is allowed to call this method more than once only the first call, however, will have an effect. True if the stream is closed. Return the underlying file descriptor (an integer) of the stream if it exists. An OSError is raised if the IO object does not use a file descriptor. Flush the write buffers of the stream if applicable. This does nothing for read-only and non-blocking streams. Return True if the stream is interactive (i.e. connected to a terminaltty device). Return True if the stream can be read from. If False. read() will raise OSError . Read and return one line from the stream. If size is specified, at most size bytes will be read. The line terminator is always bn for binary files for text files, the newline argument to open() can be used to select the line terminator(s) recognized. Read and return a list of lines from the stream. hint can be specified to control the number of lines read: no more lines will be read if the total size (in bytescharacters) of all lines so far exceeds hint . Note that it8217s already possible to iterate on file objects using for line in file. without calling file.readlines() . Change the stream position to the given byte offset . offset is interpreted relative to the position indicated by whence . The default value for whence is SEEKSET. Values for whence are: SEEKSET or 0 8211 start of the stream (the default) offset should be zero or positive SEEKCUR or 1 8211 current stream position offset may be negative SEEKEND or 2 8211 end of the stream offset is usually negative Return the new absolute position. New in version 3.1: The SEEK constants. New in version 3.3: Some operating systems could support additional values, like os.SEEKHOLE or os.SEEKDATA. The valid values for a file could depend on it being open in text or binary mode. Return True if the stream supports random access. If False. seek(). tell() and truncate() will raise OSError . Return the current stream position. Resize the stream to the given size in bytes (or the current position if size is not specified). The current stream position isn8217t changed. This resizing can extend or reduce the current file size. In case of extension, the contents of the new file area depend on the platform (on most systems, additional bytes are zero-filled). The new file size is returned. Changed in version 3.5: Windows will now zero-fill files when extending. Return True if the stream supports writing. If False. write() and truncate() will raise OSError . Write a list of lines to the stream. Line separators are not added, so it is usual for each of the lines provided to have a line separator at the end. Prepare for object destruction. IOBase provides a default implementation of this method that calls the instance8217s close() method. Base class for raw binary IO. It inherits IOBase. There is no public constructor. Raw binary IO typically provides low-level access to an underlying OS device or API, and does not try to encapsulate it in high-level primitives (this is left to Buffered IO and Text IO, described later in this page). In addition to the attributes and methods from IOBase. RawIOBase provides the following methods: Read up to size bytes from the object and return them. As a convenience, if size is unspecified or -1, readall() is called. Otherwise, only one system call is ever made. Fewer than size bytes may be returned if the operating system call returns fewer than size bytes. If 0 bytes are returned, and size was not 0, this indicates end of file. If the object is in non-blocking mode and no bytes are available, None is returned. Read and return all the bytes from the stream until EOF, using multiple calls to the stream if necessary. Read bytes into a pre-allocated, writable bytes-like object b . and return the number of bytes read. If the object is in non-blocking mode and no bytes are available, None is returned. Write the given bytes-like object. B. to the underlying raw stream, and return the number of bytes written. This can be less than the length of b in bytes, depending on specifics of the underlying raw stream, and especially if it is in non-blocking mode. None is returned if the raw stream is set not to block and no single byte could be readily written to it. The caller may release or mutate b after this method returns, so the implementation should only access b during the method call. class io. BufferedIOBase Base class for binary streams that support some kind of buffering. It inherits IOBase. There is no public constructor. The main difference with RawIOBase is that methods read(). readinto() and write() will try (respectively) to read as much input as requested or to consume all given output, at the expense of making perhaps more than one system call. In addition, those methods can raise BlockingIOError if the underlying raw stream is in non-blocking mode and cannot take or give enough data unlike their RawIOBase counterparts, they will never return None . Besides, the read() method does not have a default implementation that defers to readinto() . A typical BufferedIOBase implementation should not inherit from a RawIOBase implementation, but wrap one, like BufferedWriter and BufferedReader do. BufferedIOBase provides or overrides these methods and attribute in addition to those from IOBase : The underlying raw stream (a RawIOBase instance) that BufferedIOBase deals with. This is not part of the BufferedIOBase API and may not exist on some implementations. Separate the underlying raw stream from the buffer and return it. After the raw stream has been detached, the buffer is in an unusable state. Some buffers, like BytesIO. do not have the concept of a single raw stream to return from this method. They raise UnsupportedOperation . New in version 3.1. Read and return up to size bytes. If the argument is omitted, None. or negative, data is read and returned until EOF is reached. An empty bytes object is returned if the stream is already at EOF. If the argument is positive, and the underlying raw stream is not interactive, multiple raw reads may be issued to satisfy the byte count (unless EOF is reached first). But for interactive raw streams, at most one raw read will be issued, and a short result does not imply that EOF is imminent. A BlockingIOError is raised if the underlying raw stream is in non blocking-mode, and has no data available at the moment. Read and return up to size bytes, with at most one call to the underlying raw stream8217s read() (or readinto() ) method. This can be useful if you are implementing your own buffering on top of a BufferedIOBase object. Read bytes into a pre-allocated, writable bytes-like object b and return the number of bytes read. Like read(). multiple reads may be issued to the underlying raw stream, unless the latter is interactive. A BlockingIOError is raised if the underlying raw stream is in non blocking-mode, and has no data available at the moment. Read bytes into a pre-allocated, writable bytes-like object b . using at most one call to the underlying raw stream8217s read() (or readinto() ) method. Return the number of bytes read. A BlockingIOError is raised if the underlying raw stream is in non blocking-mode, and has no data available at the moment. New in version 3.5. Write the given bytes-like object. B. and return the number of bytes written (always equal to the length of b in bytes, since if the write fails an OSError will be raised). Depending on the actual implementation, these bytes may be readily written to the underlying stream, or held in a buffer for performance and latency reasons. When in non-blocking mode, a BlockingIOError is raised if the data needed to be written to the raw stream but it couldn8217t accept all the data without blocking. The caller may release or mutate b after this method returns, so the implementation should only access b during the method call. 16.2.3.2. Raw File IO FileIO represents an OS-level file containing bytes data. It implements the RawIOBase interface (and therefore the IOBase interface, too). The name can be one of two things: a character string or bytes object representing the path to the file which will be opened. In this case closefd must be True (the default) otherwise an error will be raised. an integer representing the number of an existing OS-level file descriptor to which the resulting FileIO object will give access. When the FileIO object is closed this fd will be closed as well, unless closefd is set to False . The mode can be r. W. x or a for reading (default), writing, exclusive creation or appending. The file will be created if it doesn8217t exist when opened for writing or appending it will be truncated when opened for writing. FileExistsError will be raised if it already exists when opened for creating. Opening a file for creating implies writing, so this mode behaves in a similar way to w. Add a to the mode to allow simultaneous reading and writing. The read() (when called with a positive argument), readinto() and write() methods on this class will only make one system call. A custom opener can be used by passing a callable as opener . The underlying file descriptor for the file object is then obtained by calling opener with ( name . flags ). opener must return an open file descriptor (passing os.open as opener results in functionality similar to passing None ). See the open() built-in function for examples on using the opener parameter. Changed in version 3.3: The opener parameter was added. The x mode was added. Changed in version 3.4: The file is now non-inheritable. In addition to the attributes and methods from IOBase and RawIOBase. FileIO provides the following data attributes: The mode as given in the constructor. The file name. This is the file descriptor of the file when no name is given in the constructor. 16.2.3.3. Buffered Streams Buffered IO streams provide a higher-level interface to an IO device than raw IO does. A stream implementation using an in-memory bytes buffer. It inherits BufferedIOBase. The buffer is discarded when the close() method is called. The optional argument initialbytes is a bytes-like object that contains initial data. BytesIO provides or overrides these methods in addition to those from BufferedIOBase and IOBase : Return a readable and writable view over the contents of the buffer without copying them. Also, mutating the view will transparently update the contents of the buffer: As long as the view exists, the BytesIO object cannot be resized or closed. New in version 3.2. Return bytes containing the entire contents of the buffer. In BytesIO. this is the same as read() . In BytesIO. this is the same as readinto() . New in version 3.5. class io. BufferedReader ( raw . buffersizeDEFAULTBUFFERSIZE ) A buffer providing higher-level access to a readable, sequential RawIOBase object. It inherits BufferedIOBase. When reading data from this object, a larger amount of data may be requested from the underlying raw stream, and kept in an internal buffer. The buffered data can then be returned directly on subsequent reads. The constructor creates a BufferedReader for the given readable raw stream and buffersize . If buffersize is omitted, DEFAULTBUFFERSIZE is used. BufferedReader provides or overrides these methods in addition to those from BufferedIOBase and IOBase : Return bytes from the stream without advancing the position. At most one single read on the raw stream is done to satisfy the call. The number of bytes returned may be less or more than requested. Read and return size bytes, or if size is not given or negative, until EOF or if the read call would block in non-blocking mode. Read and return up to size bytes with only one call on the raw stream. If at least one byte is buffered, only buffered bytes are returned. Otherwise, one raw stream read call is made. class io. BufferedWriter ( raw . buffersizeDEFAULTBUFFERSIZE ) A buffer providing higher-level access to a writeable, sequential RawIOBase object. It inherits BufferedIOBase. When writing to this object, data is normally placed into an internal buffer. The buffer will be written out to the underlying RawIOBase object under various conditions, including: when the buffer gets too small for all pending data when flush() is called when a seek() is requested (for BufferedRandom objects) when the BufferedWriter object is closed or destroyed. The constructor creates a BufferedWriter for the given writeable raw stream. If the buffersize is not given, it defaults to DEFAULTBUFFERSIZE . BufferedWriter provides or overrides these methods in addition to those from BufferedIOBase and IOBase : Force bytes held in the buffer into the raw stream. A BlockingIOError should be raised if the raw stream blocks. Write the bytes-like object. B. and return the number of bytes written. When in non-blocking mode, a BlockingIOError is raised if the buffer needs to be written out but the raw stream blocks. class io. BufferedRandom ( raw . buffersizeDEFAULTBUFFERSIZE ) A buffered interface to random access streams. It inherits BufferedReader and BufferedWriter. and further supports seek() and tell() functionality. The constructor creates a reader and writer for a seekable raw stream, given in the first argument. If the buffersize is omitted it defaults to DEFAULTBUFFERSIZE . class io. BufferedRWPair ( reader . writer . buffersizeDEFAULTBUFFERSIZE ) A buffered IO object combining two unidirectional RawIOBase objects 8211 one readable, the other writeable 8211 into a single bidirectional endpoint. It inherits BufferedIOBase . reader and writer are RawIOBase objects that are readable and writeable respectively. If the buffersize is omitted it defaults to DEFAULTBUFFERSIZE . BufferedRWPair does not attempt to synchronize accesses to its underlying raw streams. You should not pass it the same object as reader and writer use BufferedRandom instead. 16.2.3.4. Text IO Base class for text streams. This class provides a character and line based interface to stream IO. There is no readinto() method because Python8217s character strings are immutable. It inherits IOBase. There is no public constructor. TextIOBase provides or overrides these data attributes and methods in addition to those from IOBase : The name of the encoding used to decode the stream8217s bytes into strings, and to encode strings into bytes. The error setting of the decoder or encoder. A string, a tuple of strings, or None. indicating the newlines translated so far. Depending on the implementation and the initial constructor flags, this may not be available. The underlying binary buffer (a BufferedIOBase instance) that TextIOBase deals with. This is not part of the TextIOBase API and may not exist in some implementations. Separate the underlying binary buffer from the TextIOBase and return it. After the underlying buffer has been detached, the TextIOBase is in an unusable state. Some TextIOBase implementations, like StringIO. may not have the concept of an underlying buffer and calling this method will raise UnsupportedOperation . New in version 3.1. Read and return at most size characters from the stream as a single str. If size is negative or None. reads until EOF. Read until newline or EOF and return a single str. If the stream is already at EOF, an empty string is returned. If size is specified, at most size characters will be read. Change the stream position to the given offset . Behaviour depends on the whence parameter. The default value for whence is SEEKSET . SEEKSET or 0. seek from the start of the stream (the default) offset must either be a number returned by TextIOBase.tell(). or zero. Any other offset value produces undefined behaviour. SEEKCUR or 1. 8220seek8221 to the current position offset must be zero, which is a no-operation (all other values are unsupported). SEEKEND or 2. seek to the end of the stream offset must be zero (all other values are unsupported). Return the new absolute position as an opaque number. New in version 3.1: The SEEK constants. Return the current stream position as an opaque number. The number does not usually represent a number of bytes in the underlying binary storage. Write the string s to the stream and return the number of characters written. class io. TextIOWrapper ( buffer . encodingNone . errorsNone . newlineNone . linebufferingFalse . writethroughFalse ) A buffered text stream over a BufferedIOBase binary stream. It inherits TextIOBase . encoding gives the name of the encoding that the stream will be decoded or encoded with. It defaults to locale.getpreferredencoding(False) . errors is an optional string that specifies how encoding and decoding errors are to be handled. Pass strict to raise a ValueError exception if there is an encoding error (the default of None has the same effect), or pass ignore to ignore errors. (Note that ignoring encoding errors can lead to data loss.) replace causes a replacement marker (such as ) to be inserted where there is malformed data. backslashreplace causes malformed data to be replaced by a backslashed escape sequence. When writing, xmlcharrefreplace (replace with the appropriate XML character reference) or namereplace (replace with N escape sequences) can be used. Any other error handling name that has been registered with codecs.registererror() is also valid. newline controls how line endings are handled. It can be None. . n. R. and rn. It works as follows: When reading input from the stream, if newline is None. universal newlines mode is enabled. Lines in the input can end in n. R. or rn. and these are translated into n before being returned to the caller. If it is . universal newlines mode is enabled, but line endings are returned to the caller untranslated. If it has any of the other legal values, input lines are only terminated by the given string, and the line ending is returned to the caller untranslated. When writing output to the stream, if newline is None. any n characters written are translated to the system default line separator, os.linesep. If newline is or n. no translation takes place. If newline is any of the other legal values, any n characters written are translated to the given string. If linebuffering is True. flush() is implied when a call to write contains a newline character. If writethrough is True. calls to write() are guaranteed not to be buffered: any data written on the TextIOWrapper object is immediately handled to its underlying binary buffer . Changed in version 3.3: The writethrough argument has been added. Changed in version 3.3: The default encoding is now locale.getpreferredencoding(False) instead of locale.getpreferredencoding(). Don8217t change temporary the locale encoding using locale.setlocale(). use the current locale encoding instead of the user preferred encoding. TextIOWrapper provides one attribute in addition to those of TextIOBase and its parents: Whether line buffering is enabled. An in-memory stream for text IO. The text buffer is discarded when the close() method is called. The initial value of the buffer can be set by providing initialvalue . If newline translation is enabled, newlines will be encoded as if by write(). The stream is positioned at the start of the buffer. The newline argument works like that of TextIOWrapper. The default is to consider only n characters as ends of lines and to do no newline translation. If newline is set to None. newlines are written as n on all platforms, but universal newline decoding is still performed when reading. StringIO provides this method in addition to those from TextIOBase and its parents: Return a str containing the entire contents of the buffer. Newlines are decoded as if by read(). although the stream position is not changed. class io. IncrementalNewlineDecoder 16.2.4. Performance This section discusses the performance of the provided concrete IO implementations. 16.2.4.1. Binary IO By reading and writing only large chunks of data even when the user asks for a single byte, buffered IO hides any inefficiency in calling and executing the operating system8217s unbuffered IO routines. The gain depends on the OS and the kind of IO which is performed. For example, on some modern OSes such as Linux, unbuffered disk IO can be as fast as buffered IO. The bottom line, however, is that buffered IO offers predictable performance regardless of the platform and the backing device. Therefore, it is almost always preferable to use buffered IO rather than unbuffered IO for binary data. 16.2.4.2. Text IO Text IO over a binary storage (such as a file) is significantly slower than binary IO over the same storage, because it requires conversions between unicode and binary data using a character codec. This can become noticeable handling huge amounts of text data like large log files. Also, TextIOWrapper.tell() and TextIOWrapper.seek() are both quite slow due to the reconstruction algorithm used. StringIO. however, is a native in-memory unicode container and will exhibit similar speed to BytesIO . 16.2.4.3. Multi-threading FileIO objects are thread-safe to the extent that the operating system calls (such as read(2) under Unix) they wrap are thread-safe too. Binary buffered objects (instances of BufferedReader. BufferedWriter. BufferedRandom and BufferedRWPair ) protect their internal structures using a lock it is therefore safe to call them from multiple threads at once. TextIOWrapper objects are not thread-safe. 16.2.4.4. Reentrancy Binary buffered objects (instances of BufferedReader. BufferedWriter. BufferedRandom and BufferedRWPair ) are not reentrant. While reentrant calls will not happen in normal situations, they can arise from doing IO in a signal handler. If a thread tries to re-enter a buffered object which it is already accessing, a RuntimeError is raised. Note this doesn8217t prohibit a different thread from entering the buffered object. The above implicitly extends to text files, since the open() function will wrap a buffered object inside a TextIOWrapper. This includes standard streams and therefore affects the built-in function print() as well.
1-nmm-ke-biner-pilihan
Binary-option-trading-strategies-2015-calendar