Applies ToExcel για Microsoft 365 Excel 2019 Excel 2016 Excel 2013 Excel 2010

Μια προσαρμοσμένη συνάρτηση χρησιμοποιεί τη γλώσσα τύπου M, λαμβάνει ένα σύνολο τιμών εισόδου και, στη συνέχεια, επιστρέφει μια μεμονωμένη τιμή εξόδου. Εάν έχετε λογική που θέλετε να χρησιμοποιήσετε ξανά πολλές φορές ή να εφαρμόσετε το ίδιο σύνολο μετασχηματισμών σε διαφορετικό ερώτημα ή τιμή, εξετάστε το ενδεχόμενο να δημιουργήσετε μια προσαρμοσμένη συνάρτηση και, στη συνέχεια, να καλέσετε τη συνάρτηση όπου και όταν τη χρειάζεστε. Υπάρχουν πολλοί τρόποι για να δημιουργήσετε μια προσαρμοσμένη συνάρτηση: 

Ακολουθεί ένα απλό παράδειγμα προσαρμοσμένης συνάρτησης που ακολουθεί μια μακρά παράδοση προγραμματισμού.

  1. Για να δημιουργήσετε ένα κενό ερώτημα: Excel επιλογή δεδομένων> λήψη δεδομένων > από άλλες       προελεύσεις > κενό ερώτημα.Power Query      Κάντε δεξί κλικ σε ένα κενό σημείο στο παράθυρο "Ερωτήματα" στα αριστερά και, στη συνέχεια, επιλέξτε "Νέο ερώτημα" > "Άλλες > κενό ερώτημα".

  2. Στο παράθυρο "Ερωτήματα" στα αριστερά, κάντε διπλό κλικ στο όνομα και, στη συνέχεια, μετονομάστε το νέο κενό ερώτημα σε "HelloWorld".

  3. Επιλέξτε το νέο ερώτημα και, στη συνέχεια, επιλέξτε "Κεντρική"> Πρόγραμμα επεξεργασίας για προχωρημένους.

  4. Αντικαταστήστε τον κωδικό εκκίνησης προτύπου με τον ακόλουθο κώδικα:

    let      HelloWorld = () => ("Hello World") in      HelloWorld

  5. Επιλέξτε Τέλος.

  6. Έχετε αλλάξει το ερώτημα"HelloWorld", σε προσαρμοσμένη συνάρτηση. Σημειώστε το εικονίδιο συνάρτησης Εικονίδιο συνάρτησης αριστερά του.

  7. Για να καλέσετε τη συνάρτηση, επιλέξτε την και, στη συνέχεια, επιλέξτε Invoke in Data Preview.Κλήση της προσαρμοσμένης συνάρτησης HelloWorld

  8. Τα αποτελέσματα της συνάρτησης εμφανίζονται στην προεπισκόπηση δεδομένων και προστίθενται στο παράθυρο "Ερωτήματα" ως ερώτημα με το προεπιλεγμένο όνομα, "Συνάρτηση με κλήση". Μπορεί να θέλετε να το μετονομάσετε σε κάτι πιο χαρακτηριστικό, όπως "HelloWorldResult".

  9. Επιλέξτε αυτό το ερώτημα και, στη συνέχεια, επιλέξτε "Κεντρική" > "Κλείσιμο &", για να δείτε τα αποτελέσματα σε ένα φύλλο εργασίας.

Αποτελέσματα 

Αποτελέσματα του HelloWorld σε φύλλο εργασίας

Το παρακάτω παράδειγμα δείχνει πώς μπορείτε να μεταβιβάσετε μια παράμετρο σε μια προσαρμοσμένη συνάρτηση για να μετατρέψετε έναν δεκαδικό αριθμό σε δεκαεξαδικό.

  1. Για να δημιουργήσετε ένα κενό ερώτημα: Excel επιλογή δεδομένων> λήψη δεδομένων > από άλλες       προελεύσεις > κενό ερώτημα.Power Query      Κάντε δεξί κλικ σε ένα κενό σημείο στο παράθυρο "Ερωτήματα" στα αριστερά και, στη συνέχεια, επιλέξτε "Νέο ερώτημα" > "Άλλες > κενό ερώτημα".

  2. Στο παράθυρο "Ερωτήματα" στα αριστερά, μετονομάστε το νέο κενό ερώτημα σε "MyHex".

  3. Επιλέξτε το νέο ερώτημα και, στη συνέχεια, επιλέξτε "Κεντρική"> Πρόγραμμα επεξεργασίας για προχωρημένους.

  4. Αντικαταστήστε τον κωδικό εκκίνησης προτύπου με τον ακόλουθο κώδικα:

    let      MyHex = (parameter1) => Number.ToText(parameter1,"X") in      MyHex

  5. Επιλέξτε Τέλος.

  6. Έχετε αλλάξει το ερώτημα "MyHex", σε προσαρμοσμένη συνάρτηση. Σημειώστε το εικονίδιο συνάρτησης Εικονίδιο συνάρτησης αριστερά του.

  7. Για να καλέσετε τη συνάρτηση, επιλέξτε την και, στη συνέχεια, στην Προεπισκόπηση δεδομένων, πληκτρολογήστε έναν αριθμό στο πλαίσιο παράμετρος1 και επιλέξτε Invoke.

    Κλήση της προσαρμοσμένης συνάρτησης MyHex

  8. Τα αποτελέσματα της συνάρτησης εμφανίζονται στην προεπισκόπηση δεδομένων και προστίθενται στο παράθυρο "Ερωτήματα" ως ερώτημα με το προεπιλεγμένο όνομα, "Συνάρτηση με κλήση". Μπορεί να θέλετε να το μετονομάσετε σε κάτι πιο χαρακτηριστικό, όπως "MyHexResult".

  9. Επιλέξτε αυτό το ερώτημα και, στη συνέχεια, επιλέξτε "Κεντρική" > "Κλείσιμο &", για να δείτε τα αποτελέσματα σε ένα φύλλο εργασίας.

Αποτελέσματα 

Αποτέλεσμα της συνάρτησης MyHex σε ένα φύλλο εργασίας

Εάν έχετε δημιουργήσει μια συνάρτηση με τουλάχιστον μία παράμετρο, μπορείτε να την καλέσετε ως προσαρμοσμένη συνάρτηση για να δημιουργήσετε μια νέα στήλη και μια νέα τιμή για κάθε γραμμή σε έναν πίνακα.

  1. Για να ανοίξετε ένα ερώτημα, εντοπίστε ένα που έχει φορτωθεί προηγουμένως από το Πρόγραμμα επεξεργασίας του Power Query, επιλέξτε ένα κελί στα δεδομένα και, στη συνέχεια, επιλέξτε "Ερώτημα"> "Επεξεργασία". Για περισσότερες πληροφορίες, ανατρέξτε στο θέμα Δημιουργία, επεξεργασία και φόρτωση ερωτήματος στο Excel (Power Query).Σημείωση    Για αυτό το παράδειγμα, το ερώτημά σας χρειάζεται τουλάχιστον μία στήλη ενός τύπου δεδομένων "Ακέραιος αριθμός".

  2. Δημιουργήστε την προσαρμοσμένη συνάρτηση "MyHex" όπως περιγράφεται στην ενότητα, Δημιουργήστε και επικαλέστε μια προσαρμοσμένη συνάρτηση που έχει μια παράμετρο με το Πρόγραμμα επεξεργασίας για προχωρημένους.

  3. Στο ερώτημα, επιλέξτε "Προσθήκη στήλης" > "Κλήση προσαρμοσμένης συνάρτησης". Εμφανίζεται το παράθυρο διαλόγου "Κλήση προσαρμοσμένης συνάρτησης".

  4. Πληκτρολογήστε το νέο όνομα στήλης, όπως "HexConvert", στο πλαίσιο "Νέο όνομα στήλης".

  5. Επιλέξτε το όνομα μιας προκαθορισμένης προσαρμοσμένης συνάρτησης από την αναπτυσσόμενη λίστα ερωτήματος συνάρτησης. Σε αυτό το παράδειγμα, επιλέξτε "MyHex".

  6. Επειδή η προσαρμοσμένη συνάρτηση αναφέρεται σε μια παράμετρο, η παράμετρος εμφανίζεται τώρα.

  7. Επιλέξτε μια στήλη ενός τύπου δεδομένων "Ακέραιος αριθμός" ως παράμετρο της συνάρτησης.Το παράθυρο διαλόγου "Κλήση προσαρμοσμένης συνάρτησης"

  8. Επιλέξτε OK.

Αποτέλεσμα

Δημιουργείται μια νέα στήλη που εμφανίζει τη δεκαεξαδική τιμή της στήλης "Ακέραιος αριθμός" που εισαγάγατε ως παράμετρο.

Η νέα στήλη τιμών MyHex σε ένα φύλλο εργασίας

Δείτε επίσης

Βοήθεια για το Power Query Excel

Δημιουργία τύπων του Power Query σε Excel

Δημιουργία ερωτήματος παραμέτρων

Διαχείριση ερωτημάτων

Κατανόηση των συναρτήσεων του Power Query M (docs.com)

Χρήση προσαρμοσμένων συναρτήσεων (docs.com)

Χρειάζεστε περισσότερη βοήθεια;

Θέλετε περισσότερες επιλογές;

Εξερευνήστε τα πλεονεκτήματα της συνδρομής, περιηγηθείτε σε εκπαιδευτικά σεμινάρια, μάθετε πώς μπορείτε να προστατεύσετε τη συσκευή σας και πολλά άλλα.

Οι κοινότητες σάς βοηθούν να κάνετε και να απαντάτε σε ερωτήσεις, να δίνετε σχόλια και να ακούτε από ειδικούς με πλούσια γνώση.