آموزش شاخص گذاری پیشرفته در NumPy
آموزش شاخص گذاری پیشرفته در NumPy
در این درس از مجموعه آموزش برنامه نویسی سایت سورس باران، به آموزش شاخص گذاری پیشرفته در NumPy خواهیم پرداخت.
پیشنهاد ویژه : پکیج آموزش پایتون مختص بازار کار
می توان انتخابی را از ndarray انجام داد که یک توالی غیر دوتایی باشد ، یک ماده جدا کننده از نوع داده صحیح یا بولی یا یک تاپل باشد که حداقل یک مورد به عنوان یک دنباله باشد. شاخص گذاری پیشرفته همیشه یک کپی از داده را برمی گرداند. در مقابل این ، برش فقط یک دیدگاه ارائه می دهد.
دو نوع شاخص گذاری پیشرفته وجود دارد – Integer و Boolean.
شاخص گذاری عدد صحیح
این مکانیسم به انتخاب هر مورد دلخواه در آرایه بر اساس شاخص Ndimensional آن کمک می کند. هر آرایه عدد صحیح تعداد نمایه های موجود در آن بعد را نشان می دهد. وقتی ایندکس از آرایه های عدد صحیح به اندازه ابعاد تقسیم بندی هدف تشکیل شود ، مستقیم می شود.
در مثال زیر ، یک عنصر از ستون مشخص شده از هر ردیف از شی ndar ndarray انتخاب شده است. از این رو ، شاخص سطر شامل تمام شماره های سطر است و شاخص ستون عنصری را انتخاب می کند.
مثال 1
1 2 3 4 5 |
import numpy as np x = np.array([[1, 2], [3, 4], [5, 6]]) y = x[[0,1,2], [0,1,0]] print y |
خروجی آن به شرح زیر است –
1 |
[1 4 5] |
این انتخاب شامل عناصر موجود در (0،0) ، (1،1) و (2،0) از آرایه اول است.
در مثال زیر ، عناصری که در گوشه های یک آرایه 4X3 قرار گرفته اند ، انتخاب می شوند. شاخص های ردیف انتخاب [0 ، 0] و [3،3] در حالی که شاخص های ستون [0،2] و [0،2] هستند.
مثال 2
1 2 3 4 5 6 7 8 9 10 11 12 13 |
import numpy as np x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]]) print 'Our array is:' print x print '\n' rows = np.array([[0,0],[3,3]]) cols = np.array([[0,2],[0,2]]) y = x[rows,cols] print 'The corner elements of this array are:' print y |
خروجی این برنامه به شرح زیر است –
1 2 3 4 5 6 7 8 9 |
Our array is: [[ 0 1 2] [ 3 4 5] [ 6 7 8] [ 9 10 11]] The corner elements of this array are: [[ 0 2] [ 9 11]] |
انتخاب حاصل یک شی is ndarray است که حاوی عناصر گوشه ای است.
با استفاده از یک برش (:) یا بیضی (…) با آرایه فهرست می توان نمایه سازی پیشرفته و اساسی را انجام داد. مثال زیر از slice برای سطر و index پیشرفته برای ستون استفاده می کند. وقتی از برش برای هر دو استفاده می شود ، نتیجه یکسان است. اما فهرست پیشرفته کپی می شود و ممکن است طرح حافظه متفاوتی داشته باشد.
مثال 3
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
import numpy as np x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]]) print 'Our array is:' print x print '\n' # slicing z = x[1:4,1:3] print 'After slicing, our array becomes:' print z print '\n' # using advanced index for column y = x[1:4,[1,2]] print 'Slicing using advanced index for column:' print y |
خروجی این برنامه به شرح زیر است:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
Our array is: [[ 0 1 2] [ 3 4 5] [ 6 7 8] [ 9 10 11]] After slicing, our array becomes: [[ 4 5] [ 7 8] [10 11]] Slicing using advanced index for column: [[ 4 5] [ 7 8] [10 11]] |
شاخص گذاری آرایه بولی
این نوع شاخص گذاری پیشرفته زمانی مورد استفاده قرار می گیرد که هدف حاصل از این کار نتیجه عملیات بولی باشد ، مانند عملگرهای مقایسه.
مثال 1
در این مثال، موارد بزرگتر از 5 در نتیجه نشاخص گذاری بولی بازگردانده می شوند.
1 2 3 4 5 6 7 8 9 10 |
import numpy as np x = np.array([[ 0, 1, 2],[ 3, 4, 5],[ 6, 7, 8],[ 9, 10, 11]]) print 'Our array is:' print x print '\n' # Now we will print the items greater than 5 print 'The items greater than 5 are:' print x[x > 5] |
خروجی این برنامه خواهد بود –
1 2 3 4 5 6 7 8 |
Our array is: [[ 0 1 2] [ 3 4 5] [ 6 7 8] [ 9 10 11]] The items greater than 5 are: [ 6 7 8 9 10 11] |
مثال 2
در این مثال ، عناصر NaN (Not a Number) با استفاده از ~ (عملگر متمم) حذف می شوند.
1 2 3 |
import numpy as np a = np.array([np.nan, 1,2,np.nan,3,4,5]) print a[~np.isnan(a)] |
خروجی آن خواهد بود –
1 |
[1. 2. 3. 4. 5.] |
مثال 3
مثال زیر نحوه فیلتر کردن عناصر غیر پیچیده از یک آرایه را نشان می دهد.
1 2 3 |
import numpy as np a = np.array([1, 2+6j, 5, 3.5+5j]) print a[np.iscomplex(a)] |
در اینجا، خروجی به شرح زیر است –
1 |
[2.0 + 6.j 3.5 + 5.j] |
دیدگاه شما