CountIf statement excel - excel

I want to be able to check if data in one cell in column a = x and then if so count the data in adjacent cell in column b.
To explain in more detail, I am creating a statistics chart where commissioners need to be able to be able to compare data for region 1 to region 2 and region 3.
So column A will contain region keys such as 1, 1, 1, 2, 3, 3 then in column B will be ages. So if column A contains a 1 collect data in cell adjacent to the cell it is counting.
I hope this makes sense.
So I want the formula to only count the cells that adjacent cells contain district 1 for example
table, th, td {
border: 1px solid black;
border-collapse: collapse;
}
<table style="width:100%">
<tr>
<td>A</td>
<td>B</td>
</tr>
<tr>
<td>District 1</td>
<td>12</td>
</tr>
<tr>
<td>District 2</td>
<td>12</td>
</tr>
<tr>
<td>District 1</td>
<td>12</td>
</tr>
<tr>
<td>District 2</td>
<td>12</td>
</tr>
</table>

You just need to use COUNTIFS() to add extra criteria to when to count something.
Using the following data:
Region Age
2 12
2 16
2 41
1 62
3 26
3 50
2 12
1 65
3 64
Where Region = B1 we can use =COUNTIFS(A2:A10,2,B2:B10,12) to count the instances where Region = 2 and where Age = 12. This returns 2.
Obviously we can expand this out to all manner of criteria or keep adding extra criteria. Having data that looks like:
Region Age Ethnicity
2 12 Black
2 16 Caucasian
2 41 Asian
1 62 Black
3 26 Caucasian
3 50 Asian
2 12 Caucasian
1 65 Caucasian
3 64 Asian
We can now count Asian people equal to or over the age of 50 in region 3 with =COUNTIFS(A2:A10,3,B2:B10,">=50",C2:C10,"Asian")
And if you want to bucket people using upper and lower bounds it's simply a case of creating the bound in separate ranges and criteria pairs. For instance to find all people in region 2 aged between 10 and 20 (not inclusive on the upper bound) we would use =COUNTIFS(A2:A10,2,B2:B10,">=10",B2:B10,"<20")

Related

Excel If Function for Multiple If's

For the below, I'm looking for an excel if function that'll let me know how old each of the items are (less than 3 days, Less than 7 days, Less than 14 days, Greater than 14 days)
Create a table outlining your cut offs and then use a VLOOKUP.
In C2, add =VLOOKUP(TODAY()-B2,$F$2:$G$6,2,1) and drag down as needed
The benefit with going this route is that you don't have to update complicated IF statements if you ever needed to change the buckets. Say for instance, in the future you want to add 5 more categories. Here that would just mean updating 5 rows on a single table rather nesting 5 more criteria to an IF statement.
A simple verbose formula...
=IF(TODAY()-B3<=7,"Less than equal to seven",IF(TODAY()-B3<=14,"Less than or
equal to fourteen days",IF(TODAY()-B3<=21,"Less than or equal to twenty one
days","greater than 21 days")))
Need to format the cell this is in as a number with no decimal places.
This formula should do the trick:
=IF((TODAY()-B1)<3,"Less than 3 days",
IF((TODAY()-B1)<7,"Less than 7 days",
IF((TODAY()-B1)<14,"Less than 14 days",
IF((TODAY()-B1)>=14,"Greater than 14 days",""))))
Please notice that I used >=14.
Reason is otherwise you wont get the rows where the difference is exactly 14.
But feel free to change it to >14 if that's fit your need better :)
you can use tha TODAY() function to get the current date and than compare it with the dates you have:
so the table that you will have is like:
table, th, td {
border: 1px solid black;
}
<table style="width:100%">
<tr>
<th>5/12/2020</th>
<th>=TODAY()-B1</th>
<th>=if(C1<3, "less than 3 days", if(C1<7, "less than 7 days", if(C1<14, "less than 14 days", "more than 14 days")))
</th>
</tr>
<tr>
<th>5/10/2020</th>
<th>=TODAY()-B2</th>
<th>=if(C1<3, "less than 3 days", if(C1<7, "less than 7 days", if(C1<14, "less than 14 days", "more than 14 days")))
</th>
</tr>
</table>

How to add multiple columns in reset_index from a pandas- series

Am having a pandas series & i need to show it's elements in columnar fashion embedded in an email body with HTML.Hence tried below snippet. It worked for me initially with two columns, but now i have three columns to display. Here is code-
a = max_compare.rename_axis('Metric').reset_index(name='Yesterday').to_html()
Here max_compare is series with below output-
<table border="1" class="dataframe">
<thead>
<tr style="text-align: right;">
<th></th>
<th>Metric</th>
<th>Yesterday</th>
</tr>
</thead>
<tbody>
<tr>
<th>0</th>
<td>GSV</td>
<td>4424180.0</td>
</tr>
<tr>
<th>1</th>
<td>Units</td>
<td>7463.0</td>
</tr>
</tbody>
</table>
Now i am having another element to be shown in column. Tried below code snippet, but got exception.
a =max_compare.rename_axis('Metric').reset_index(name=['Yesterday'],[L30 average]).to_html()
Current Output in HTML
Output-
Since you do not provide any data sample nor expected result, I do not know exactly what you want to do. However, this is how to reset a MultiIndex.
level : int, str, tuple, or list, default None
Only remove the given levels from the index. Removes all levels by default
Link to the documentation
import pandas as pd
import io
# Paste the text by using of triple-quotes to span String literals on multiple lines
zz = """index grade class numgrade numyear
0 A Senior 12 4
1 A Junior 12 3
2 A Junior 12 3
3 A Senior 12 4
4 A Junior 12 3
"""
df = pd.read_table(io.StringIO(zz), delim_whitespace=True)
df.set_index(['index', 'grade'], inplace=True)
# Reset the two levels
df.reset_index(level=(0,1))
Edit
The same method can be used with Series. But Reseting a MultiIndex of a Series will convert it back to a DataFrame since Series, by definition, have only one column (a value) and an index. In consequence, I think you should use DataFrame if you want to deal with more than one column.
# Paste the text by using of triple-quotes to span String literals on multiple lines
zz = """index grade class
0 A Senior
1 A Junior
2 A Junior
3 A Senior
4 A Junior
"""
df = pd.read_table(io.StringIO(zz), delim_whitespace=True)
df.set_index(['index', 'grade'], inplace=True)
# Creating a series with a multiIndex
se = df.iloc[:,0]
print(type(se))
# Reseting index also works for Series.
# In case of MultiIndex, Series will be converted back
# to a DataFrame since Series, by definition, have
# only one column and an index
se.reset_index(level=(0,1))
# <class 'pandas.core.series.Series'>
# index grade class
# 0 0 A Senior
# 1 1 A Junior
# 2 2 A Junior
# 3 3 A Senior
# 4 4 A Junior

Comparative condition in table

I want to the below excel sheet if Total Deposit table is less than to Total Cost table - it's automatically subtract at Manager Get table, and if Total Deposit table is greater than to Total Cost table- it's automatically subtract at Customer Get table. If Total Cost & Total Deposit are equal then the both of Customer get and Manager Get table show NO Due.I am extremely sorry,i could not upload excel snap-short image for my poor reputation . but i did it by html code . To clarify my question plz run the the code
<!DOCTYPE html>
<html>
<head>
<style>
table, th, td {
border: 1px solid black;
border-collapse: collapse;
}
th, td {
padding: 2px;
}
</style>
</head>
<body>
<table style="width:100%">
<tr>
<th>Total Cost</th>
<th>Total deposit</th>
<th>Customer Get</th>
<th>Manager Get</th>
</tr>
<tr>
<td>2700</td>
<td>2500</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>2500</td>
<td>2900</td>
<td>-</td>
<td>-</td>
</tr>
<tr>
<td>2300</td>
<td>2300</td>
<td>-</td>
<td>-</td>
</tr>
</table>
</body>
</html>
So it seems you have 3 conditions:
if Total Deposit table is less than to Total Cost table - it's automatically subtract at Manager Get table
if Total Deposit table is greater than to Total Cost table- it's
automatically subtract at Customer Get table
If Total Cost & Total Deposit are equal then the both of Customer get and Manager Get table show NO Due
I believe we can accomplish that using 2 formulas. Assuming the data starts in A1:
Formula for Customer Get:
=IF(B2>A2,B2-A2,IF(B2=A2,"NO Due","-"))
Formula for Manager Get:
=IF(B2<A2,A2-B2,IF(B2=A2,"NO Due","-"))
You can then autofill the formula down:
Total Cost Total deposit Customer Get Manager Get
2700 2500 =IF(B2>A2,B2-A2,IF(B2=A2,"NO Due","-")) =IF(B2<A2,A2-B2,IF(B2=A2,"NO Due","-"))
2500 2900 =IF(B3>A3,B3-A3,IF(B3=A3,"NO Due","-")) =IF(B3<A3,A3-B3,IF(B3=A3,"NO Due","-"))
2300 2300 =IF(B4>A4,B4-A4,IF(B4=A4,"NO Due","-")) =IF(B4<A4,A4-B4,IF(B4=A4,"NO Due","-"))
And the result looks like:
Total Cost Total deposit Customer Get Manager Get
2700 2500 - 200
2500 2900 400 -
2300 2300 NO Due NO Due

How to match different charts

Below I have two charts, the first does not have the value of calories, the second does. (The values are arbitrary - this is just an example.) I need to find a way to fill in the value of the calories in the first chart by matching all the values of wheat, flour, barley, and rye with the second chart. If all the values match, then I need it to copy that number of calories into the first chart. For example, row 2 has matching values with row 13, so I need to copy 100 calories into the E2 cell.
Does anyone have a formula that can do this?
A B C D E
1 Wheat Flour Barley Rye Calories
2 1 0 0 2
3 4 2 4 0
4 1 4 5 2
5 0 3 2 1
6 1 6 8 9
10 KEY
11 A B C D E
12 Wheat Flour Barley Rye Calories
13 1 0 0 2 100
14 0 3 2 1 150
Insert a column between Rye and Calories, in E12 enter =A12&B12&C12&D12 and copy down to suit.
In F2 enter =VLOOKUP(A2&B2&C2&D2,E$13:F$14,2,0) (or extend range if required) and copy down to suit.
This assumes both arrays are in the same sheet.
Tidy up by selecting ColumnF, Copy, Paste Special..., Values over the top and then delete ColumnE.
I'm new so can't post pics... I added a column to be the new A column that details different weight measurements (1.0 grams, 1.25 grams etc)
In cell B3 (or whatever cell is directly under Wheat at the top, paste the following and then paste over and across:
+IFERROR(INDEX($B$9:$F$16,MATCH($A3,$A$9:$A$16,0),MATCH(B$2,$B$8:$F$8,0)),0)
where $B$9:$F$16 is your whole table of original data
where $A3 is your identifier in your top chart (1.0 grams in my example)
where $A$9:$A$16 is the range in your data chart that lists gram measurements (1.0 grams - 10.0 grams or whatever)
where B$2 is Wheat in top chart
where $B$8:$F$8 is Wheat to Calories in bottom chart.
Hope this helps.

Color Theory: How to convert Munsell HVC to RGB/HSB/HSL

I'm looking at at document that describes the standard colors used in dentistry to describe the color of a tooth. They quote hue, value, chroma values, and indicate they are from the 1905 Munsell description of color:
The system of colour notation
developed by A. H. Munsell in 1905
identifies colour in terms of three
attributes: HUE, VALUE (Brightness)
and CHROMA (saturation) [15]
HUE (H): Munsell defined hue as the
quality by which we distinguish one
colour from another. He selected five
principle colours: red, yellow, green,
blue, and purple; and five
intermediate colours: yellow-red,
green-yellow, blue-green, purple-blue,
and red-purple. These were placed
around a colour circle at equal points
and the colours in between these
points are a mixture of the two, in
favour of the nearer point/colour (see
Fig 1.).
VALUE (V): This notation indicates the
lightness or darkness of a colour in
relation to a neutral grey scale,
which extends from absolute black
(value symbol 0) to absolute white
(value symbol 10). This is essentially
how ‘bright’ the colour is.
CHROMA (C): This indicates the degree
of divergence of a given hue from a
neutral grey of the same value. The
scale of chroma extends from 0 for a
neutral grey to 10, 12, 14 or farther,
depending upon the strength
(saturation) of the sample to be
evaluated.
There are various systems for
categorising colour, the Vita system
is most commonly used in Dentistry.
This uses the letters A, B, C and D to
notate the hue (colour) of the tooth.
The chroma and value are both
indicated by a value from 1 to 4. A1
being lighter than A4, but A4 being
more saturated than A1. If placed in
order of value, i.e. brightness, the
order from brightest to darkest would
be:
A1, B1, B2, A2, A3, D2, C1, B3, D3,
D4, A3.5, B4, C2, A4, C3, C4
The exact values of Hue, Value and
Chroma for each of the shades is shown
below (16)
So my question is, can anyone convert Munsell HVC into RGB, HSB or HSL?
Hue Value (Brightness) Chroma(Saturation)
=== ================== ==================
4.5 7.80 1.7
2.4 7.45 2.6
1.3 7.40 2.9
1.6 7.05 3.2
1.6 6.70 3.1
5.1 7.75 1.6
4.3 7.50 2.2
2.3 7.25 3.2
2.4 7.00 3.2
4.3 7.30 1.6
2.8 6.90 2.3
2.6 6.70 2.3
1.6 6.30 2.9
3.0 7.35 1.8
1.8 7.10 2.3
3.7 7.05 2.4
They say that Value(Brightness) varies from 0..10, which is fine. So i take 7.05 to mean 70.5%.
But what is Hue measured in? i'm used to hue being measured in degrees (0..360). But the values i see would all be red - when they should be more yellow, or brown.
Finally, it says that Choma/Saturation can range from 0..10 ...or even higher - which makes it sound like an arbitrary scale.
So can anyone convert Munsell HVC to HSB or HSL, or better yet, RGB?
It is rather involved. The short answer is, converting Munsell codes into RGB involves interpolation of empirical data in 3D that is highly non-linear. The only data set that is publicly available was collected in the 1930's. Free or inexpensive programs that I have found on the net have proved to be flawed. I wrote my own. But I am jumping ahead. Let's start with the basics.
Munsell codes are different in kind than those other codes, xyY, Lab, and RGB. Munsell notation describes the color of an object - what people experience when they view the object. (Isaac Newton was the first to realize that color is in the eye of the beholder.) Munsell conducted extensive experiments with human subjects and ingenious devices.
The other codes, i.e. xyY, Lab*, and RGB, describe light that has bounced off an object and passed through a convolultion with a rather simple mathematical model of a human eye. Some google-terms are "illuminant," "tri-stimulus," and "CIE standard observer."
Munsell describes the colors of objects as they are perceived under a wide variety of illuminants. Another google-term is "chromatic adaptation." Chromatic adaptation in the brain is automatic if the lighting is not too weird. It is really quite remarkable. Take a piece of typing paper outside under a blue sky. The paper looks white. Take it indoors and look at it under incandescent (yellowish) lights. It still looks white! Munsell tapped into that astonishing processing power empirically. Munsell codes also preserve perceived hue at different chromas. A sky-blue and a powder-blue that Munsell assigns the same hue notation, e.g. 5RP, will appear to the typical human with normal eyesight to be the same hue. More on that in the footnote.
CIE xyY, Lab*, and RGB mean nothing unless an illuminant is specified. Chromatic adaptation for illuminants in the mathematical model is computationally difficult. (Rough but simple approximations can be done using the "Bradford matrices.") The RGB that we use is by default "sRGB," which specifies an illuminant called D65. D65 is something like a cloudless day at noon. The Lab numbers listed by the OP are probably relative to D50, which is more like afternoon or morning light. The xyY numbers might be relative to D50, or they might be relative to an old standard called C. I am not going to check. C was the light from a standard lighting fixture that was relatively inexpensive to build in the 1930's. It is obsolete. But C plays a key role in the answer to the question.
In the 1930's, color scientists were developing the mathematical models. One of the things they did was to take a standard Munsell Book of Color, shine illuminant-C light on the colored chips in the book, and record the data in xyY format. That data-set, called the "Munsell Renotation Data," is the only one that is freely available. Others surely exist, but they are closely held secrets.
Good news though. The data set works good. The Munsell authority today is a company called Gretag Macbeth. I imagine they have voluminous data related to the color-chips they sell. The only numbers I know of that they publish are the D50 Lab and D65 sRGB numbers for a small set of colors on their "Color Checker" cards. I wrote an interpolator based on the old renotation data. It agrees with the numbers for the Color Checker card almost exactly. I regret to inform that so far I have only written code for the conversion that goes the opposite direction from what the OP requested (a year ago, as I type this). It goes from sRGB to Munsell. I click on an image, and the program displays the sRGB and Munsell notations for the area clicked upon. I use it for oil painting.
Footnote: CIE has a standard that is analogous to Munsell. It is called LCh subscripted with a,b. It is Lab* in polar coordinates. The hues are in degrees. Chroma numbers are approximately 5 times the C in Munsell HVC. LCh has its problems though. If you have ever used a photo editor to pump up the vividness of the sky, only to see the blue turn to purple, the program was probably using LCh. When I started writing my program, I was unaware that Bruce Lindloom had done work that parallels what I was doing. His web site was invaluable to me as I finished the project. He designed a space he calls UPLab, which is LCh straightened out to align with Munsell. I had already re-invented LCh and (essentially) UPLab before I discovered Mr. Linbloom's site, but his knowledge of the subject far exceeds mine.
Munsell Renotation System to sRGB Colourspace Conversion
Colour, our open source Python colour science package allows to perform that conversion.
From Munsell Renotation System to CIE xyY Colourspace
The following two definitions based on Centore (2012) method converts between Munsell Renotation System and CIE xyY colourspace:
munsell_colour_to_xyY
xyY_to_munsell_colour
From CIE xyY Colourspace to sRGB Colourspace
Converting from CIE xyY colourspace to sRGB colourspace is done by first converting to CIE XYZ tristimulus values and then to sRGB colourspace using the following definitions:
xyY_to_XYZ
XYZ_to_sRGB
Implementation
Here is an annotated complete example using the above definitions:
import colour
# The *Munsell Renotation System* colour we would like to convert
# to *sRGB* colourspace.
MRS_c = '4.2YR 8.1/5.3'
# The first step is to convert the *MRS* colour to *CIE xyY*
# colourspace.
xyY = colour.munsell_colour_to_xyY(MRS_c)
# We then perform conversion to *CIE xyY* tristimulus values.
XYZ = colour.xyY_to_XYZ(xyY)
# The last step will involve using the *Munsell Renotation System*
# illuminant which is *CIE Illuminant C*:
# http://nbviewer.ipython.org/github/colour-science/colour-ipython/blob/master/notebooks/colorimetry/illuminants.ipynb#CIE-Illuminant-C
# It is necessary in order to ensure white stays white when
# converting to *sRGB* colourspace and its different whitepoint
# (*CIE Standard Illuminant D65*) by performing chromatic
# adaptation between the two different illuminant.
C = colour.ILLUMINANTS['CIE 1931 2 Degree Standard Observer']['C']
RGB = colour.XYZ_to_sRGB(XYZ, C)
print(RGB)
[ 0.96820063 0.74966853 0.60617991]
You can also perform the reverse conversion from sRGB colourspace to Munsell Renotation System:
import colour
C = colour.ILLUMINANTS['CIE 1931 2 Degree Standard Observer']['C']
RGB = (0.96820063, 0.74966853, 0.60617991)
print(colour.xyY_to_munsell_colour(colour.XYZ_to_xyY(colour.sRGB_to_XYZ(RGB, C))))
4.2YR 8.1/5.3
References
Centore, P. (2012). An open-source inversion algorithm for the Munsell renotation. Color Research & Application, 37(6), 455–464. doi:10.1002/col.20715
The hue specification you've given here is incomplete (4.5 should be 4.5Y etc). Since the link is dead, if anyone is interested, the specs are still alive here:
http://web.archive.org/web/20071103065312/http://lib.umich.edu/dentlib/Dental_tables/Colorshadguid.html
The only free utility for Munsell conversion I could find was this:
http://web.archive.org/web/20020809130910/standards.gretagmacbeth.com/cmc/munsell.exe
Very old as you can see, but seems to work well. Current programs that can do this are not free:
http://livingstonmanor.net/Munsell2/index.htm
http://www.babelcolor.com/main_level/download.htm (this one has a free 14 day trial)
The current holders of the Munsell products are X-Rite, they probably have some conversion solutions as well.
Further, note that the link you supplied includes definitions for the same colors in other color coordinates - namely Yxy and CIE lab*. Both can be freely converted online at http://www.colorpro.com/info/tools/convert.htm or offline with this free color converter
For completeness, here's the archive.org version of my page, that contains the colors in 3 colorspaces, Munsell, Yxy and Lab:
Vita shade-guide colors
_________________________________________________________________
Munsell Chromaticity
notation coordinates CIE L* a* b*
(ref 151) (ref 152) (ref 151)
_____________ _____________________ ___________________
Shade H V C Y x y L* a* b*
_________________________________________________________________
A1 4.5Y 7.80/1.7 55.92 0.3352 0.3459 79.57 -1.61 13.05
A2 2.4Y 7.45/2.3 49.95 0.3468 0.3539 76.04 -0.08 16.73
A3 1.3Y 7.40/2.9 48.85 0.3559 0.3593 75.36 1.36 19.61
A3.5 1.6Y 7.05/3.2 44.12 0.3627 0.3657 72.31 1.48 21.81
A4 1.6Y 6.70/3.1 38.74 0.3633 0.3658 68.56 1.58 21.00
B1 5.1Y 7.75/1.6 54.76 0.3336 0.3447 78.90 -1.76 12.33
B2 4.3Y 7.50/2.2 50.97 0.3437 0.3549 76.66 -1.62 16.62
B3 2.3Y 7.25/3.2 46.91 0.3611 0.3669 74.13 0.47 22.34
B4 2.4Y 7.00/3.2 43.38 0.3620 0.3678 71.81 0.50 22.15
C1 4.3Y 7.30/1.6 47.16 0.3361 0.3462 74.21 -1.26 12.56
C2 2.8Y 6.95/2.3 42.12 0.3487 0.3563 70.95 -0.22 16.72
C3 2.6Y 6.70/2.3 39.11 0.3499 0.3569 68.83 -0.01 16.68
C4 1.6Y 6.30/2.7 33.77 0.3600 0.3622 64.78 1.59 18.66
D2 3.0Y 7.35/1.8 48.71 0.3391 0.3473 75.27 -0.54 13.47
D3 1.8Y 7.10/2.3 44.48 0.3482 0.3534 72.55 0.62 16.14
D4 3.7Y 7.05/2.4 43.45 0.3492 0.3591 71.86 -1.03 17.77
_________________________________________________________________
H hue
V value
C chroma
Y lightness
x and y hue and chroma
L* lightness
a* hue and chroma on a red/green scale
b* hue and chroma on a yellow/blue scale
References
151 O'Brien, W.J., Groh, C.L., and Boenke, K.M. A new, small- color-difference equation for dental shades. J.Dent. Res. 69:1762-1764, 1990.
152 O'Brien, W.J., Groh, C.L., and Boenke, K.M. Unpublished data. University of Michigan School of Dentistry, Ann Arbor.
There is a free R package munsell which will (among other things) convert Munsell codes to RGB:
R> library(munsell)
R> mnsl2hex("5PB 5/10")
[1] "#3B75BB"
There's a page I've found here: munsell-to-rgb.blogspot.com that seems to be doing exactly what you are after. It seems unfinished at the moment, but the owner of the blog plans to update it regularly with as many Munsell-to-RGB conversions as he can (and he takes requests!).
It's amazing how hard it is to find accessible conversion tables for these colour systems; hopefully this will be our answer! :D
I'm late to the party, but I found another resource that may be useful on this topic.
Someone at the "Munsell Color Science Laboratory" dug up some 1943 data from Munsell, all based on 1930s Munsell research: http://www.cis.rit.edu/research/mcsl2/online/munsell.php
The page refers to an Excel spreadsheet with the "real colors only" subset of the data that falls within the "Macadam limit", which appears to mean the gamut of colors that can actually appear on reflective surfaces. The spreadsheet link doesn't work, however, but on a hunch I guessed that it left out one level of the directory tree. I tried the URL http://www.cis.rit.edu/research/mcsl2/online/real_sRGB.xls -- and it worked. (I wouldn't be surprised if the owner of the site eventually notices it, and fixes the link, which is likely to break my link.)
I messed with that spreadsheet a little to get it to generate HTML to show me the RGB colors, and added these cells to the spreadsheet:
<table>
.<colgroup> <col /> <col span="3" style="background-color:#eeeeee;" /> <col span="3" /> <col span="3" style="background-color:#eeeeee;" /> <col span="3" /> <col span="3" style="background-color:#eeeeee;" /> <col span="3" /> <col style="background-color:#eeeeee;" /> <col /> </colgroup>
="<tr> <th> "&A1&" </th> <th> "&B1&" </th> <th> "&C1&" </th> <th> "&D1&" </th> <th> "&E1&" </th> <th> "&F1&" </th> <th> "&G1&" </th> <th> "&H1&" </th> <th> "&I1&" </th> <th> "&J1&" </th> <th> "&K1&" </th> <th> "&L1&" </th> <th> "&M1&" </th> <th> "&N1&" </th> <th> "&O1&" </th> <th> "&P1&" </th> <th> "&Q1&" </th> <th> "&R1&" </th> <th> "&S1&" </th> <th> #RGB </th> <th> sample </th> </tr> "
="<tr> <td> "&A2&" </td> <td> "&B2&" </td> <td> "&C2&" </td> <td> "&D2&" </td> <td> "&E2&" </td> <td> "&F2&" </td> <td> "&G2&" </td> <td> "&H2&" </td> <td> "&I2&" </td> <td> "&J2&" </td> <td> "&K2&" </td> <td> "&L2&" </td> <td> "&M2&" </td> <td> "&N2&" </td> <td> "&O2&" </td> <td> "&P2&" </td> <td> "&Q2&" </td> <td> "&R2&" </td> <td> "&S2&" </td> <td> #"&T2&" <td style="&CHAR(34)&"background-color:#"&T2&"; width:2em;"&CHAR(34)&"> </td> </tr> "
="<tr> <td> "&A3&" </td> <td> "&B3&" </td> <td> "&C3&" </td> <td> "&D3&" </td> <td> "&E3&" </td> <td> "&F3&" </td> <td> "&G3&" </td> <td> "&H3&" </td> <td> "&I3&" </td> <td> "&J3&" </td> <td> "&K3&" </td> <td> "&L3&" </td> <td> "&M3&" </td> <td> "&N3&" </td> <td> "&O3&" </td> <td> "&P3&" </td> <td> "&Q3&" </td> <td> "&R3&" </td> <td> "&S3&" </td> <td> #"&T3&" <td style="&CHAR(34)&"background-color:#"&T3&"; width:2em;"&CHAR(34)&"> </td> </tr> "
="<tr> <td> "&A4&" </td> <td> "&B4&" </td> <td> "&C4&" </td> <td> "&D4&" </td> <td> "&E4&" </td> <td> "&F4&" </td> <td> "&G4&" </td> <td> "&H4&" </td> <td> "&I4&" </td> <td> "&J4&" </td> <td> "&K4&" </td> <td> "&L4&" </td> <td> "&M4&" </td> <td> "&N4&" </td> <td> "&O4&" </td> <td> "&P4&" </td> <td> "&Q4&" </td> <td> "&R4&" </td> <td> "&S4&" </td> <td> #"&T4&" <td style="&CHAR(34)&"background-color:#"&T4&"; width:2em;"&CHAR(34)&"> </td> </tr> "
.
.
.
="<tr> <td> "&A1626&" </td> <td> "&B1626&" </td> <td> "&C1626&" </td> <td> "&D1626&" </td> <td> "&E1626&" </td> <td> "&F1626&" </td> <td> "&G1626&" </td> <td> "&H1626&" </td> <td> "&I1626&" </td> <td> "&J1626&" </td> <td> "&K1626&" </td> <td> "&L1626&" </td> <td> "&M1626&" </td> <td> "&N1626&" </td> <td> "&O1626&" </td> <td> "&P1626&" </td> <td> "&Q1626&" </td> <td> "&R1626&" </td> <td> "&S1626&" </td> <td> #"&T1626&" <td style="&CHAR(34)&"background-color:#"&T1626&"; width:2em;"&CHAR(34)&"> </td> </tr> "
</table>
The table needs one line each of the ones starting with A2 through A1626, and one each of the others.
I hope this helps.
Despite this old post, to update Steve's answer, here are "corrected" links to RIT's repositories of Munsell data:
https://www.rit.edu/cos/colorscience/rc_munsell_renotation.php
And a direct link to spreadsheet of the sRGB converted values of the "real" Munsell colors:
http://www.rit-mcsl.org/MunsellRenotation/real_sRGB.xls
It's a spreadsheet which includes a conversion from Munsell HVC notation to xyY, then to XYZ_C, then converted to D65 illuminant, then to floating point sRGB, then quantized to 8bit sRGB values (which they call dRGB).
As for the OP's question: sRGB is (obviously) an RGB additive color model. But the differences to other color models such as subtractive CMYK are complex enough that a "simple" algorithm won't handle the conversion — while color model transformations can be approximated with a matrix, more often a LUT (Look Up Table) is preferred, such as a LUT in an ICC profile or a 3D LUT as used in film production. (Not all ICC profiles are LUT based, but a LUT based conversion IMO is what is needed here).
The Munsell data certainly falls into this category, as not only is it a different color model, it is not only a subtractive model it is based on perception, while sRGB is based on a simple relationship between red green and blue light.
The spreadsheet is the useable look-up-table, so then a program to convert things like your dental chart to sRGB would take in that data and reference the LUT contained in the spreadsheet, and return the sRGB values.
Side Note: I want to mention for clarity that although some color-space or color-model transforms can be done reasonably with an algorithm/matrix, 3D LUTs are preferred particularly when the LUTs are created from measured data of a given color-model/space, which maps the many non-linearities inherent in some models.
An extreme example is an sRGB image on your computer monitor vs how that image is printed onto paper and appears on the cover of a magazine sitting on a newsstand illuminated with florescent light. That requires a 3D LUT for an accurate transformation!
In the feature film industry (where I mostly work) we use 3D LUTs throughout the image pipeline, not just for converting/transforms, but for "viewing" and for applying/emulating "looks." For instance taking an image shot with a digital camera and applying a LUT of a certain film stock to that image to make it appear as film.
Since many of the resources of days long past seem to be dwindling away or, as Microsoft puts it, "is not intended for this version of Windows", scraping together as many resources, converters and look-up-tables as possible, is what this Q&A has turned into. Allow me to add one more, then.
Andrew Werth, a US artist, has a tool on their site to convert from Munsell to RGB and HTML hex codes. It's all inside one single .htm file, so I guess it could be downloaded and used on one's desktop as a sort of tool. Actually, that's what I did.
https://www.andrewwerth.com/color/
I like the art, too.

Resources