Μετάβαση στο κύριο περιεχόμενο

Πώς να επιτρέψετε μόνο αρνητικούς αριθμούς στο Excel;

Στο Excel, πώς να επιτρέπεται η εισαγωγή μόνο αρνητικών αριθμών; Αυτό το άρθρο θα παρουσιάσει μερικά χρήσιμα και γρήγορα κόλπα για να επιλύσετε αυτήν την εργασία.

Να επιτρέπονται μόνο αρνητικοί αριθμοί στο Excel με επικύρωση δεδομένων

Να επιτρέπονται μόνο αρνητικοί αριθμοί στο Excel με κωδικό VBA


βέλος μπλε δεξιά φούσκα Να επιτρέπονται μόνο αρνητικοί αριθμοί στο Excel με επικύρωση δεδομένων

Κανονικά, το επικύρωση δεδομένων Η λειτουργία μπορεί να σας βοηθήσει, κάντε τα εξής:

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

το doc επιτρέπει μόνο αρνητικό 1

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

(1.) Στο Επιτρέψτε τμήμα, επιλέξτε Δεκαδικός από την αναπτυσσόμενη λίστα.

(2.) Στο ημερομηνία ενότητα, παρακαλώ επιλέξτε μικρότερη ή ίση με επιλογή;

(3.) Επιτέλους, εισαγάγετε τον αριθμό 0 μέσα στο Ανώτατο όριο πλαίσιο κειμένου.

το doc επιτρέπει μόνο αρνητικό 2

3. Στη συνέχεια κάντε κλικ στο κουμπί OK, και τώρα, επιτρέπεται η εισαγωγή μόνο αρνητικών αριθμών και 0, εάν εισαχθεί θετικός αριθμός, θα εμφανιστεί ένα προειδοποιητικό μήνυμα, δείτε το στιγμιότυπο οθόνης:

το doc επιτρέπει μόνο αρνητικό 3


βέλος μπλε δεξιά φούσκα Να επιτρέπονται μόνο αρνητικοί αριθμοί στο Excel με κωδικό VBA

Εδώ είναι ένας κωδικός VBA που μπορεί επίσης να σας βοηθήσει, με τον ακόλουθο κωδικό, όταν εισαγάγετε έναν θετικό αριθμό, θα μετατραπεί σε αρνητικό αυτόματα, κάντε τα εξής:

1. Κάντε δεξί κλικ στην καρτέλα φύλλων που θέλετε να επιτρέψετε μόνο αρνητικούς αριθμούς και επιλέξτε Προβολή κωδικού από το μενού περιβάλλοντος, στο αναδυόμενο Microsoft Visual Basic για εφαρμογές παράθυρο, αντιγράψτε και επικολλήστε τον ακόλουθο κώδικα στο κενό Μονάδα μέτρησης:

Κωδικός VBA: Να επιτρέπονται μόνο αρνητικοί αριθμοί στο φύλλο εργασίας:

Private Sub Worksheet_Change(ByVal Target As Range)
'Updateby Extendoffice
    Const sRg As String = "A1:A1000"
    Dim xRg As Range
    On Error GoTo err_exit:
    Application.EnableEvents = False
    If Not Intersect(Target, Range(sRg)) Is Nothing Then
        For Each xRg In Target
            If Left(xRg.Value, 1) <> "-" Then
                xRg.Value = xRg.Value * -1
            End If
        Next xRg
    End If
err_exit:
    Application.EnableEvents = True
End Sub

το doc επιτρέπει μόνο αρνητικό 4

Note: Στον παραπάνω κώδικα, A1: A1000 είναι τα κελιά που θέλετε να εισάγετε μόνο αρνητικούς αριθμούς.

2. Στη συνέχεια, αποθηκεύστε και κλείστε αυτόν τον κωδικό, επιστρέψτε το φύλλο εργασίας και τώρα, όταν εισαγάγετε ορισμένους θετικούς αριθμούς στα κελιά που καθορίσατε στον κώδικα, οι θετικοί αριθμοί θα μετατραπούν αυτόματα σε αρνητικούς.

Τα καλύτερα εργαλεία παραγωγικότητας γραφείου

Δημοφιλή χαρακτηριστικά: Εύρεση, επισήμανση ή αναγνώριση διπλότυπων   |  Διαγραφή κενών γραμμών   |  Συνδυάστε στήλες ή κελιά χωρίς απώλεια δεδομένων   |   Γύρος χωρίς φόρμουλα ...
Σούπερ Αναζήτηση: VLookup πολλαπλών κριτηρίων    VLookup πολλαπλών τιμών  |   VLookup σε πολλά φύλλα   |   Ασαφής αναζήτηση ....
Σύνθετη αναπτυσσόμενη λίστα: Γρήγορη δημιουργία αναπτυσσόμενης λίστας   |  Εξαρτημένη αναπτυσσόμενη λίστα   |  Πολλαπλή αναπτυσσόμενη λίστα ....
Διαχειριστής στήλης: Προσθέστε έναν συγκεκριμένο αριθμό στηλών  |  Μετακίνηση στηλών  |  Εναλλαγή κατάστασης ορατότητας κρυφών στηλών  |  Συγκρίνετε εύρη και στήλες ...
Επιλεγμένα Χαρακτηριστικά: Εστίαση πλέγματος   |  Προβολή σχεδίου   |   Μεγάλη Formula Bar    Διαχείριση βιβλίου εργασίας & φύλλου   |  Βιβλιοθήκη πόρων (Αυτόματο κείμενο)   |  Επιλογή ημερομηνίας   |  Συνδυάστε φύλλα εργασίας   |  Κρυπτογράφηση/Αποκρυπτογράφηση κελιών    Αποστολή email ανά λίστα   |  Σούπερ φίλτρο   |   Ειδικό φίλτρο (φίλτρο με έντονη γραφή/πλάγια γραφή/διαγραφή...) ...
Κορυφαία 15 σύνολα εργαλείων12 Κείμενο Εργαλεία (Προσθήκη κειμένου, Κατάργηση χαρακτήρων, ...)   |   50 + Διάγραμμα Τύποι (Gantt διάγραμμα, ...)   |   40+ Πρακτικό ΜΑΘΗΜΑΤΙΚΟΙ τυποι (Υπολογίστε την ηλικία με βάση τα γενέθλια, ...)   |   19 Εισαγωγή Εργαλεία (Εισαγωγή κωδικού QR, Εισαγωγή εικόνας από το μονοπάτι, ...)   |   12 Μετατροπή Εργαλεία (Αριθμοί σε λέξεις, Μετατροπή Συναλλάγματος, ...)   |   7 Συγχώνευση & διαχωρισμός Εργαλεία (Σύνθετες σειρές συνδυασμού, Διαίρεση κελιών, ...)   |   ... κι αλλα

Αυξήστε τις δεξιότητές σας στο Excel με τα Kutools για Excel και απολαύστε την αποτελεσματικότητα όπως ποτέ πριν. Το Kutools για Excel προσφέρει πάνω από 300 προηγμένες δυνατότητες για την ενίσχυση της παραγωγικότητας και την εξοικονόμηση χρόνου.  Κάντε κλικ εδώ για να αποκτήσετε τη δυνατότητα που χρειάζεστε περισσότερο...

kte καρτέλα 201905


Το Office Tab φέρνει τη διεπαφή με καρτέλες στο Office και κάνει την εργασία σας πολύ πιο εύκολη

  • Ενεργοποίηση επεξεργασίας και ανάγνωσης καρτελών σε Word, Excel, PowerPoint, Publisher, Access, Visio και Project.
  • Ανοίξτε και δημιουργήστε πολλά έγγραφα σε νέες καρτέλες του ίδιου παραθύρου και όχι σε νέα παράθυρα.
  • Αυξάνει την παραγωγικότητά σας κατά 50% και μειώνει εκατοντάδες κλικ του ποντικιού για εσάς κάθε μέρα!
Comments (4)
No ratings yet. Be the first to rate!
This comment was minimized by the moderator on the site
How do I change the automatic formatting with this code from Currency to Accounting ?
This comment was minimized by the moderator on the site
Hi! Great article. One question: if, instead of a coherent group of cells, I want to apply this in different parts of the sheet (e.g. A1:A2 AND A6:A8), is there a way to do that with the VBA solution? I.e.: how do I replace the "A1:A1000" with several sets of cells?
This comment was minimized by the moderator on the site
Hello, GB,
To apply this code for multiple ranges, please use the following code:

Note: when using this code, first, you should right click the sheet tab, and then click View code from the context menu, and then copy the following code into the module.

Private Sub Worksheet_Change(ByVal Target As Range)
'Updateby Extendoffice
Const sRg As String = "A1:A10,B1:B10,C1:C20" 'Separate the ranges by commas
Dim xRg As Range
Dim xSRg As Range
On Error GoTo err_exit:
Application.EnableEvents = False
Set xSRg = Range(sRg)
If Not Intersect(Target, xSRg) Is Nothing Then
For Each xRg In Target
If Left(xRg.Value, 1) <> "-" Then
xRg.Value = xRg.Value * -1
End If
Next xRg
End If
err_exit:
Application.EnableEvents = True
End Sub

Please try, hope it can help you!
This comment was minimized by the moderator on the site
Super, thanks! Very helpful.
There are no comments posted here yet
Please leave your comments in English
Posting as Guest
×
Rate this post:
0   Characters
Suggested Locations