We propose a novel stochastic gradient method-semi-stochastic coordinate descent (S2CD)-for the problem of minimizing a strongly convex function represented as the average of a large number of smooth convex functions: f (x) = 1 n i f i (x). Our method first performs a deterministic step (computation of the gradient of f at the starting point), followed by a large number of stochastic steps. The process is repeated a few times, with the last stochastic iterate becoming the new starting point where the deterministic step is taken. The novelty of our method is in how the stochastic steps are performed. In each such step, we pick a random function f i and a random coordinate j-both using nonuniform distributions-and update a single coordinate of the decision vector only, based on the computation of the j th partial derivative of f i at two different points. Each random step of the method constitutes an unbiased estimate of the gradient of f and moreover, the squared norm of the steps goes to zero in expectation, meaning that the stochastic estimate of the gradient progressively improves. The complexity of the method is the sum of two terms: O(n log(1/ǫ)) evaluations of gradients ∇f i and O(κ log(1/ǫ)) evaluations of partial derivatives ∇ j f i , whereκ is a novel condition number.